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PHP 是 应 用 非常 广泛 的 互联 网 开发 语言 之 一 ， 而 PHP + MySQL + Dre- 
amweaver 是 目前 最 热门 的 网 站 开发 组 合 。 全 书 共 10 章 ， 通过 大 量 实际 项 
目的 案例 ， 详 尽 地 讲解 了 PHP 的 技术 要 点 和 开发 过 程 ， 精 选 动态 功能 模 
块 实例 ， 通 过 实例 的 讲解 来 让 读者 理解 PHP + MySQL + Dreamweaver 的 动 
态 开发 方法 。 全 书包 括 用 户 管理 系统 、 新 闻 发 布 系统 、 留 言 板 管理 系统 、 
投票 管理 系统 、BBS 论坛 管理 系统 和 网 上 购物 系统 等 6 个 综合 案例 。 

本 书 内 容 丰 富 ， 实 用 性 和 操作 性 强 ， 配 备 有 素材 光盘 ， 适 合 学 习 PHP 
+ MySQL + Dreamweaver 动态 网 页 制作 的 初级 读者 ， 也 适合 作为 高 等 院 校 
本 、 专 科 相 关 专 业 动 态 网 页 制作 课程 的 教材 ， 还 可 以 作为 网 站 开发 爱好 者 
的 自学 参考 书 。 
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PHP 是 当前 最 流行 的 Web 编程 语言 之 一 ， 有 具有 开源 和 免费 的 优势 。MySQL 是 一 个 广 受 
欢迎 的 中 型 关系 数据 库 管 理 系 统 ， 它 免费 、 快 速 、 跨 平台 ,并 且 支 持 多 线程 、 多 用 户 ， 满 足 
重负 载 的 性 能 要 求 。 使 用 PHP + MySQL 进行 Web 应 用 系统 开发 是 一 种 非常 理想 的 选择 。 

与 其 他 类 似 的 计算 机 图 书 相 比 ， 本 书 具 有 以 下 几 点 特色 : 

四 内 容 选 编 简 明 扼 要 

一 般 的 PHP 书籍 会 介绍 很 多 理论 知识 ， 但 本 书 选编 内 容 简 明 扼要 ， 适 合 初 学 者 学 习 使 
用 。 介 绍 PHP + MySQL 的 基础 知识 时 ， 利 用 每 一 节 介 绍 一 个 知识 点 并 同步 配 以 实例 加 以 理 
解 应 用 。 全 书 主题 鲜明 、 要 点 明确 ， 介 绍 了 制作 网 页 的 技巧 和 规范 ， 可 以 让 读者 快速 学 会 使 
用 Dreamweaver CC 2014 按照 规范 进行 网 站 开发 。 

晤 从 入 门 到 高 手 导向 清晰 

书 中 的 所 有 实例 均 出 自作 者 多 年 来 开发 的 商业 应 用 实例 ， 认 真 学 习 第 1 ~3 章 即 可 以 掌 
握 平 台 的 搭建 、PHP 和 MySQL 配合 开发 的 基础 知识 。 第 4 ~6 章 结 合 Dreamweaver 的 集成 动 
态 功 能 ， 快 速 掌 握 在 Dreamweaver 中 开发 PHP 动态 系统 的 功能 。 第 7 ~ 10 章 学 习 手 写 PHP 
代码 实现 动态 系统 的 开发 ， 成 为 真正 的 PHP 网 页 开发 高 手 。 每 章 的 实例 均 符合 所 讲解 的 知 
识 点 ， 实 现 了 实践 与 理论 相 结合 ， 对 于 读者 在 制作 中 的 思路 整理 、 开 发 创意 会 有 所 帮助 。 

四 附 赠 资源 丰富 

读者 可 以 从 www. empbook. com 下 载 本 书 的 教学 多 媒体 PPT 文件 及 书 中 所 用 网 站 源 代码 
和 素材 ， 是 读者 轻松 掌握 PHP 网 站 开发 的 最 佳 素 材 宝 典 。 读 者 也 可 以 加 入 本 书 专用 QQ FE 
( 群 号 : 298191658) 获得 附 赠 资源 并 与 作者 及 其 他 读者 交流 经 验 技巧 。 

本 书 详细 介绍 了 PHP 和 MySQL 开发 的 基础 知识 、 技 术 要 点 ， 并 结合 PHP 和 MySQL Hj 
述 了 动态 网 站 的 开发 方法 。 全 书 共 分 10 草 ， 各 章 的 详细 内 容 如 下 。 

第 1 章 介 绍 了 PHP + MySQL 开发 平台 搭建 的 知识 ， 详 细 说 明了 PHP 5.0 的 基础 知识 ， 
集成 环境 Xammp 的 搭建 和 使 用 ，Apache 服务 器 的 安装 与 配置 ，PHP 环境 的 安装 与 配置 ， 
MySQL 数据 库 的 安装 与 管理 以 及 解决 数据 库 中 文 乱码 问题 。 

第 2 章 介 绍 了 PHP 的 编程 基础 ， 这 是 使 用 Dreamweaver 开发 网 站 的 第 一 步 ， 介 绍 了 在 
Dreamweaver 中 进行 PHP 开发 平台 的 搭建 ，PHP 程序 编写 的 基础 知识 ，PHP 表单 变量 的 使 
JH, PHP 程序 中 常量 、 变 量 、 表 达 式 以 及 函数 的 基础 ， 其 中 要 重点 掌握 PHP 和 MySQL 数据 
库 的 操作 。 

第 3 章 介 绍 了 在 Dreamweaver 中 实现 动态 功能 的 基础 操作 ， 重 点 介绍 了 PHP 开发 的 流 
程 ， 搭 建 PHP 动态 系统 开发 的 平台 ,检查 数据 库 记 录 的 常见 操作 和 编辑 记录 的 常见 操作 。 

第 4 章 介 绍 了 一 个 典型 的 用 户 管理 系统 。 在 动态 网 站 中 ， 用 户 管理 系统 是 非常 必要 的 。 
通过 用 户 注 册 信 息 的 统计 ， 可 以 让 管理 员 了 解 到 网 站 的 访问 情况 ;通过 用 户 权 限 的 设置 ， 可 
以 限制 网 站 页 面 的 访问 权限 。 一 个 用 户 管理 系统 ， 一 般 应 该 具备 用 户 注册 功能 、 资 料 修改 功 
能 、 取 回 密 码 功能 以 及 用 户 注 销 身 份 等 功能 。 


































































PHP-x*MySQL Dreamweaver 动态 网 站 开发 从 入 门 到 精通 


第 5 章 着 重 介 绍 了 新 闻 发 布 系统 的 实现 方法 。 新 闻 发 布 系统 是 常见 的 网 站 系统 ， 尤 其 是 
政府 单位 、 教 育 单位 或 企业 网 站 。 新 闻 发 布 系统 的 作用 就 是 在 网 上 传播 信息 ， 通 过 对 新 闻 的 
不 断 更 新 ， 让 用 户 及 时 了 解 行业 信息 、 企 业 状 况 。 所 以 新 闻 发 布 系统 中 涉及 的 主要 操作 就 是 
访问 者 的 新 闻 查 询 功 能 和 系统 管理 员 对 新 闻 的 新 增 、 修 改 、 删 除 功能 ， 使 用 PHP 实现 这 些 
功能 相对 比较 简单 。 

第 6 章 介 绍 了 留言 板 管理 系统 的 制作 方法 。 留 言 板 可 以 实现 网 站 与 访问 者 之 间 的 沟通 ， 
收集 用 户 意见 和 信息 ， 也 是 网 站 建设 必 不 可 少 的 一 个 重要 系统 。 利 用 留言 板 ， 可 以 为 访问 人 
员 提 供 发 言 的 机 会 ， 让 他 们 及 时 、 准 确 地 发 表 上 自己 的 观点 。 这 些 观点 被 保留 在 服务 器 上 的 数 
据 库 中 ， 而 且 可 以 被 任何 一 个 访问 站 点 的 人 看 到 。 

第 7 章 介绍 了 投票 管理 系统 的 开发 方法 。 一 个 投票 管理 系统 大 体 可 分 为 3 个 模块 : 选票 
模块 、 选 票 处 理 模 块 以 及 结果 显示 模块 。 投 票 管理 系统 首先 给 出 选票 选 题 ， 即 供 投 票 者 选择 
的 表单 对 象 ， 当 投票 者 单 击 选择 投票 按钮 后 ， 选 票 处 理 模块 激活 ， 对 服务 器 传送 过 来 的 数据 
做 出 相应 的 处 理 ， 先 判断 用 户 选择 的 是 哪 一 项 ， 把 相应 字段 的 值 加 1， 然后 对 数据 进行 更 
新 ， 最 后 将 结果 显示 出 来 。 

第 8 章 介绍 了 BBS 论坛 管理 系统 的 开发 。 将 学 习 使 用 PHP 实现 BBS 论坛 的 开发 方法 。 
BBS 论坛 通常 按 不 同 的 主题 划分 为 很 多 版 块 ， 按 照 版 块 或 者 栏目 的 不 同 ， 可 以 由 管理 员 设 立 
不 同 的 版 主 ， 版 主 可 以 对 自己 的 栏目 或 版 块 进行 删除 、 修 改 或 者 锁定 等 操作 。 

第 9 章 制作 了 一 个 电子 商务 网 站 的 前 台 开 发 方法 。 主 要 介绍 使 用 PHP 进行 网 上 购物 系 
统 前 台 开 发 的 方法 ， 系 统 地 介绍 了 网 上 购物 系统 的 设计 。 数 据 库 的 规划 以 及 常用 的 几 个 功能 
模块 前 台 的 开发 。 

第 10 章 介 绍 电子 商务 网 站 的 后 台 功 能 开发 方法 。 一 个 完善 的 网 上 购物 系统 并 不 只 是 提 
供给 用 户 注册 、 进 行 购物 等 功能 。 它 还 要 给 网 站 所 有 者 一 个 功能 齐全 的 后 台 管 理 功能 。 网 站 
所 有 者 登录 后 台 管 理 即 可 发 布 新 公告 、 管 理会 员 注 册 、 回 复 留言 、 维 护 商 品 ， 以 及 管理 
订单 。 

本 书 是 为 PHP 开发 初 、 中 级 读者 特别 编写 的 图 书 ， 书 中 应 用 到 了 Dreamweaver CC 2014 
的 扩展 应 用 如 “服务 器 行为 ”面板 的 绑 定 ， 可 以 方便 初学 者 快速 实现 PHP 的 动态 功能 开发 ， 
读者 在 下 载 Dreamweaver CC 版 本 后 需要 安装 Adobe Extension Manage CC ， 然 后 再 下 载 Depre- 
cated, ServerBehaviorsPanel, Support. zxp 扩展 安装 即 可 以 完全 使 用 。 

本 书 由 拥有 将 近 10 年 网 站 建设 经 验 的 资深 设计 师 编 写 ， 实现 了 理论 、 实 践 相 结 合 ， 章 
节 安 排 合理 ， 注 重 了 内 容 的 实用 性 、 可 操作 性 。 本 书 由 环 博文 化 的 陈 益 材 主编 ， 另 有 于 和 荷 
云 、 官 斯 文 、 邹 亮 、 王 炎 光 、 耿 国 续 、 陈 益 红 、 秦 树 德 、 张 馈 运 、 赵 红 、 陈 章 、 任 霖 参与 了 
编写 工作 。 由 于 作者 水 平 有 限 ， 加 之 创作 时 间 人 仓促， 本 书 玻 漏 之 处 在 所 难免 ， 欢 迎 各 位 读者 
与 专家 批评 指正 。 
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第 E] e ”搭建 PHP 网 站 建设 平台 


PHP 是 一 项 很 有 前 途 的 动态 网 页 技术 ， 是 最 普及 、 应 用 最 广泛 的 Web 开发 语言 之 一 ， 
其 独特 的 语法 混合 了 C、jJava、Perl 以 及 PHP 自 创 的 新 的 语法 。 它 具有 开放 的 源 代码 和 多 种 
数据 库 的 支持 ， 并 且 支 持 跨 平台 的 操作 和 面向 对 象 的 编程 ， 而 且 是 完全 免费 的 。 掌 握 这 个 技 
术 的 开发 也 并 不 困难 。 在 学 习 实际 的 网 页 程序 编写 之 前 ， 首 要 的 就 是 利用 自己 的 操作 系统 搭 
建 一 个 适合 PHP 开发 的 操作 平台 。 现 在 的 操作 系统 只 要 是 Windows XP、Windows 7 等 ， 从 
操作 角度 上 来 说 可 以 搭建 集成 的 XAMPP 环境 ; 也 可 以 独立 在 这 几 个 操作 平台 搭建 PHP， 只 
需 使 用 Apache (或 者 IIS 因特网 信息 服务 系统 ) + Dreamweaver + MySQL 即 可 。 由 于 Win- 
dows 7 操作 系统 比较 普及 ， 本 章 就 将 讲解 如 何在 Windows 7 中 进行 PHP 操作 平台 的 配置 。 对 
于 初学 者 建议 直接 安装 XAMPP 集成 环境 进行 学 习 。 





oy VAVBESEIGU 


主要 掌握 以 下 知识 点 : 


PHP 5.0 的 基础 知识 

XAMPP 集成 环境 的 安装 和 使 用 
Apache 服务 器 的 安装 与 配置 
PHP 环境 的 安装 与 配置 
MySQL 数据 库 的 安装 与 管理 
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PHP 基础 知识 


PHP 是 一 种 多 用 途 脚本 语言 ， 尤 其 适合 于 Web 应 用 程序 开发 。 利 用 PHP 强大 的 扩展 
性 ， 可 以 在 服务 端 连 接 Java 应 用 程序 ， 还 可 以 与 . NET 建立 有 效 的 沟通 甚至 更 广阔 的 扩展 ， 
从 而 可 以 建立 一 个 强大 的 环境 ， 以 充分 利用 现 有 的 和 其 他 技术 开发 的 资源 。 同 时 ， 开 源 和 跨 
平台 的 特性 使 得 使 用 PHP 架构 能 够 快速 、 高 效 地 开发 出 可 移植 的 、 跨 平台 的 、 具 有 强大 功 
能 的 企业 级 Web 应 用 程序 。 


[pir PHP 5. 0 特性 


PHP 是 超 文 本 预 处 理 语言 PHP; Hypertext Preprocessor 的 递归 缩写 ， 是 一 种 HTML Pj tix 
式 的 语言 。 它 与 微软 的 ASP 相似 ， 都 是 一 种 在 服务 器 端 执行 、 竺 入 HTML 文档 的 脚本 语言 ， 
语言 的 风格 又 类 似 于 C 语言 ， 现 在 被 很 多 的 网 站 编程 人 员 广 泛 地 应 用 。 

与 其 他 编程 语言 做 出 的 动态 页 面相 比 ，PHP 是 将 程序 嵌入 到 HTML 文档 中 去 执行 ， 执 
行 效率 比 完全 生成 HTML 标记 的 CGI 要 高 许多 。 与 同样 是 府 入 HTML 文档 的 脚本 语言 JavaS- 
cript HEE, PHP 在 服务 器 端 执 行 ， 充 分 利用 了 服务 器 的 性 能 。PHP 执行 引擎 还 会 将 用 户 经 
常 访问 的 PHP 程序 驻 留 在 内 存 中 ， 其 他 用 户 再 一 次 访问 这 个 程序 时 就 不 需要 重新 编译 程序 ， 
只 要 直接 执行 内 存 中 的 代码 就 可 以 ， 这 也 是 PHP 高 效率 的 体现 之 一 。 图 1-1 所 示 为 PHP 的 
运行 模式 。PHP 还 具有 非常 强大 的 功能 ， 所 有 的 CGI 或 者 JavaScript 的 功能 PHP 都 能 实现 ， 
而 且 支 持 几 乎 所 有 流行 的 数据 库 以 及 操作 系统 。 

















Apache 网 站 服务 器 MySQL 数据 库 服务 器 
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图 1-1 PHP 运行 模式 





PHP 最 初 只 是 用 Perl 语言 编写 的 简单 的 程序 ， 用 来 统计 网 站 的 访问 量 。 后 来 又 用 C 语 
言 重 新 编写 ， 增 加 了 可 以 访问 数据 库 等 功能 ， 并 在 1995 年 发 布 了 PHP 1.0, 2004 年 7 月 13 
H PHP 5. 0 正式 版 本 的 发 布 ， 标 志 着 一 个 全 新 的 PHP 时 代 的 到 来 。 它 的 核心 是 第 二 代 Zend 
引擎 ， 并 引入 了 对 全 新 的 PECL 模块 的 支持 。 在 不 断 更 新 的 同时 ，PHP 5. 0 依然 保留 了 对 旧 
PHP 4.0 程序 的 兼容 。 随 着 MySQL 数据 库 的 发 展 ，PHP 5.0 还 绑 定 了 新 的 MySQL 扩展 模块 ， 
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提供 了 一 些 更 加 有 效 的 方法 和 实用 工具 用 于 处 理 数 据 库 操作 。PHP 5.0 添加 了 面向 对 象 的 
PDO (PHP Data Objects) 模块 ， 提供 了 另外 一 种 数据 库 操作 的 方案 ,统一 数据 库 操作 的 
API。 另 外 ，PHP 5.0 中 还 改进 了 创建 动态 图 片 的 功能 ， 目 前 能 够 支持 多 种 图 片 格式 (如 
PNG, GIF, TIF, JPEG 等 )。PHP 5.0 已 经 内 置 了 对 GD2 库 的 支持 ， 因 此 安装 CD2 JE ( 主 O) 
要 指 UNIX 系统 中 ) 也 不 再 是 件 难事 ， 这 使 得 处 理 图 像 十 分 简单 和 高 效 。 

PHP 5. 0 还 增加 了 只 有 成 熟 的 编程 语言 体系 结构 中 才 有 的 一 些 特性 ， 如 下 面 列 出 的 这 些 。“ 人 e 甘 | 
特性 。 

(1) 增强 的 面向 对 象 能 力 。PHP 5.0 的 最 大 特点 是 引入 了 面向 对 象 的 全 部 机 制 ， 并 且 保 
留 了 向 下 的 兼容 性 。 程 序 员 不 必 再 编写 缺乏 功能 性 的 类 ， 并 且 能 够 以 多 种 方法 实现 类 的 保 
护 。 另 外 ， 在 对 象 的 集成 等 方面 也 不 再 存在 问题 。 使 用 PHP 5. 0 引进 的 类 型 提示 和 异常 处 理 
机 制 ， 能 更 有 效 地 处 理 和 避免 错误 的 发 生 。PHP 5. 0 增加 了 很 多 功能 ， 例 如 ， 显 式 构造 函数 
和 析 构 函数 、 对 象 克隆 、 类 抽象 、 变 量 作用 域 和 接口 等 。 

(2) try/catch 异常 处 理 。 从 PHP 5.0 开始 文 持 异常 处 理 。 在 许多 语言 中 ， 如 C ++ 、C#、 
Python 和 Java 等 ， 异 常 处 理 长 期 以 来 一 直 都 是 错误 管理 方面 的 中 流 丰 柱 ， 为 建立 标准 化 的 
错误 报告 逻辑 提供 了 一 种 绝 佳 的 方法 。 

(3) 字符 串 处 理 。 之 前 版 本 的 PHP 默认 将 字符 串 看 作 数 组 ， 这 也 反映 了 PHP 原先 的 数 
据 类 型 观点 不 够 严密 。 这 种 策略 在 版 本 5.0 中 有 所 调整 ， 引 入 了 一 种 专门 的 字符 串 偏 移 量 
(offset) 语法 ， 而 之 前 的 方法 已 经 废弃 不 用 。 

(4) XML 和 Web 服务 支持 。 现 在 的 XML 支持 建立 在 libxml2 库 基 础 上 ， 并 引入 一 个 很 
新 并 且 非 常 有 前 途 的 扩展 包 来 解析 和 处 理 XML: SimpleXML。 此 外 ，PHP 5.0 还 支持 SOAP 
扩展 。 

(5) 对 SQLite W A Ex iF, PHP 5.0 为 功能 强大 、 简 洁 的 SQLite 数据 库 服 务 需 
( http ;//www. sqlite. org). 提供 了 支持 。 如 果 开 发 人 员 需 要 使 用 一 些 只 有 重量 级 数据 库 产品 中 
才 有 的 特性 ， 同 时 不 希望 带 来 相应 的 管理 开销 ， 则 SQLite 是 一 个 很 好 的 解决 方案 。 


Er PHP 开发 环境 | 


在 开始 学 习 PHP 之 前 ， 首 先 需 要 配置 PHP 的 运行 环境 。PHP 的 运行 环境 需要 两 个 软件 
的 支持 : 一 个 是 PHP 运行 的 Web 服务 器 
Apache， 而 在 具体 安装 Apache 服务 器 之 前 
首先 要 在 运行 的 系统 上 安装 支持 Apache 服 | 
务 器 的 Java 2 SDK; 另 一 个 是 PHP 运行 时 需 第 二 步 : 安装 配置 PHP php 
要 加 载 的 主要 软件 包 ， 该 软件 包 主 要 是 解释 
执行 PHP 页 面 的 脚本 程序 ， 如 解释 PHP 页 ”第 三 步 : 安装 配置 MySQL 数 据 库 | 
面 的 函数 。 本 书 主要 介绍 Windows 操作 系统 UN 
下 使 用 Apache PHP 配置 环境 的 方法 。 第 四 步 : 管理 数据 库 ， 解 决 中 文 乱码 

PHP 开发 运行 环境 的 需求 如 图 1-2 所 示 。 






































第 一 步 : 安装 Apache 服 务 器 Apa 























图 1-2 PHP 环境 配置 步骤 
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PHP+MYSQL+Dreamweaver 





XAMPP 环境 安装 和 使 用 





XAMPP ( Apache + MySQL + PHP + PERL) 是 一 个 功能 强大 的 开发 动态 PHP. 网 站 的 集成 
软件 包 。 非 常 适合 新 手 安装 使 用 ， 这 个 软件 包 原 来 的 名 字 是 LAMPP， 但 是 为 了 避免 误解 ， 
最 新 的 几 个 版 本 改名 为 XAMPP。 它 可 以 在 Windows, Linux, Solaris 三 种 操作 系统 下 安装 使 
用 ,支持 多 语言 英文、 简体 中 文 、 繁 体 中文 、 韩 文 、 俄 文 、 日 文 等 。 


|. XAMPP 集成 套件 下 载 


XAMPP 是 到 目前 为 止 最 好 用 的 一 款 Apache + MySQL + PHP 套件 ， 它 同时 支持 Zend 
Optimizer， 支 持 插件 安装 。 最 新 XAMPP 的 版 本 是 5. 6. 3。 下 载 的 方法 如 下 : 

1) 打开 浏览 器 ， 输 入 官方 网 址 ，http://www. apachefriends. org/ ， 按 下 (Enter) EJF, 
再 单 击 “ 简 体 中 文 ”切换 到 中 文 版 本 页 面 ， 再 单 击 导航 栏 上 的 XAMPP 国 下 载 按钮 ， 进 入 
下 载 页 面 ， 如 图 1-3 所 示 。 




















E 360 安 全 浏览 器 7.1 «malsv|—|eom| x 
S | > QC Q *r OÂ https://www.apachefriends.org/zh_cn/index.html GEAM 
1> | © | [E] XAMPP Installers and Down! x | + Go 
XAMPP 是 完全 免费 且 易 于 安装 的 Apache 发 行 版 ， 其 中 包含 MYSQL、PHP 和 Perl。XAMPP 开 放 源码 包 的 设置 让 安装 和 使 用 出 奇 容易 。 
为 什么 要 使 用 XAMPP? 


。 最 流行 的 PHP 开 发 包 p 
。 适用 于 Windows、Mac OS X 和 Linux 

。 快速 安装 和 配置 

。 完全 免费 


ES XAMPP for Windows 
v5.6.3 (PHP 5.6.3) 


A XAMPP for Linux 
v5.6.3 (PHP 5.6.3) 


€& X^MPP foros X 
v5.6.3 (PHP 5.6.3) 























图 1-3 进入 下 载 页 面 


2) 单 击 页 面 上 的 “XAMPP for Windows” 文 字 链接 ， 进 入 “XAMPP for Windows” FR 
页 面 ， 如 图 1-4 所 示 。 

3) 单 击 选择 “下 载 ” 按 钮 ， 下 载 最 新 xampp - win32-5. 6. 3 -0 -VC11-installer exe 安 
装 包 ， 如 图 1-5 所 示 。 

XAMPP 完全 免费 并 且 遵 循 GNU 通用 公众 许可 ，XAMPP 目前 包含 的 功能 模块 如 下 : 

* Use PHP version for XAMPP version, 
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居 360 安 全 浏览 器 7.1 < 菜单 [ 曾 | 一 口 x 
C 仓 ú 9 Â https//www.apachefriends.org/zh cn/download success.html BY 
D | © | [EXAMP Installers and Down! x | [E] XAMPP Download Success x | 十 B5 








Apache Friends 下 载 Hosting 








新 建 下 载 任务 


网 址 : | http://125.39.35.133/files/4175 





ZFR: | xampp-win32-5.6.3-0-VC11-installer.exe ”软件 143.91 MB 














下 载 到 : | CNUsers\Douglas\Desktop 和 到 50.1 GB v 





| © SATSAA 
读 取 中 


请 确保 你 仔细 阅读 了 安装 说 明和 常见 D EE v 





* Linux 常见 问题 

。 Windows 常见 问题 

* OSX 常 见 问题 

你 可 以 在 我 们 的 论坛 或 Stack Overflow 上 找到 更 多 帮助 。 


将 XAMPP 告 诉 你 的 好 友 $ 
图 1-4 Windows 版 的 下 载 页 面 


























下 载 - 云 加 速 由 迅雷 提供 支持 


| xampp-win32-5.6.3-0-VC11-installer.exe 143.91 MB - 5.78M/S 00:00:11 四 o Q 


$ SFE : 578M/S 




















图 1-5 下 载 最 新 版 的 安装 包 
* Updated PHP to 5. 6.3, 

* Updated MySQL to 5. 6. 21, 

* Updated phpMyAdmin to 4. 2. 11, 

* Update OpenSSL to 1. 0. 1j. 

€ New XAMPP welcome page (beta), 


CI XAMPP 的 安装 测试 过 程 


XAMPP 的 安装 过 程 很 简单 ， 解 压 包 等 就 更 简单 一 点 。 本 书 以 Windows 7 操作 系统 中 安 
装 XAMPP 为 例 具体 步骤 如 下 : 

1) 安装 时 最 好 放置 到 C: 盘 ， 但 要 注意 在 Windows 7 中 可 能 需要 修改 写 和 权限， 双击 下 
载 的 文件 安装 包 ， 打 开 如 图 1-6 所 示 的 提示 安装 注意 事项 。 

2) 单 击 “OK” 按 钮 ， 提 示 将 开始 安装 XAMPP 组 件 ， 如 图 1-7 所 示 。 
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Setup - XAMPP 


Welcome to the XAMPP Setup Wizard. 


A Important! Because an activated User Account Control (UAC) on your 

A, uem some functions of XAMPP are possibly restricted. With UAC please © bitnami 
avoid to install XAMPP to C:\Program Files (x86) (missing write | 
permisssions). Or deactivate UAC with msconfig after this setup. | 


| 
| | < Back | Next> Cancel 


图 1-6 开始 安装 图 1-7 开始 安装 面板 












































3) 单 击 “Next”( 下 一 步 ) 按钮 ， 打开“Select Components. (选择 安装 组 件 ) ”对话 框 ， 
这 里 选择 需要 安装 的 软件 ， 勾 选 相应 的 组 件 进行 安装 ， 如 图 1-8 所 示 。 


Select Components 





Select the components you want to install; clear the components you do not want to install. Click Next 
when you are ready to continue. 
E [V] Server 

IV] Apache 

| MySQL 

FileZilla FTP Server 
T] Mercury Mail Server 










































































Program Languages 
phpMy&dmin 
Webalizer 
Fake Sendmail 









































XAMPP Installer 








< Back Next» Cancel 





图 1-8 选择 安装 的 组 件 


4) 单 击 “Next (下 一 步 )” 按 钮 ， 打 开 “Jnstallation folder. (选择 安装 路 径 ) ”对 话 框 ， 
这 里 选择 在 C: 盘 下 安装 ， 如 图 1-9 所 示 。 
Vista 以 上 操作 系统 由 于 对 Vista 默认 安装 的 C:\program files 文件 夹 没有 足够 的 写 权 限 ， 


推荐 为 XAMPP 安装 创建 新 的 路 径 ， 如 C:\XAMPP 或 D:\XAMPP。 
5) 设置 完 路 径 之 后 ， 单 击 “Next (下 一 步 )” 按 钮 ,打开 “Bitnami for XAMPP ( Bitna- 


mi 对 XAMPP 环境 安装 的 支持 ) ”对 话 框 ， 取 消 Learn more about Bitnami for XAMPP (了 解 更 
多 的 知识 ) 复 选 框 ， 如 图 1-10 所 示 。 
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ifs] Setup o ——À,—]À w«- 


Installation folder 


Please, choose a folder to install XAMPP 


Select a folder. C:^xamprl 














XAMPP Installer 














fe Setup 


Bitnami for XAMPP B 


Bitnami for XAMPP provides free installers that can install 








Drupal, Joomlal, WordPress and many other popular open 
source apps on top of your existing XAMPP installation. 
1 https: //bitnami.com/«ampp 


Learn more about Bitnami for XAMPP | | 











XAMPP Installer 











图 1-10 取消 复 选 框 


6) 单 击 “Next (下 一 步 )” 按 钮 ,打开 “Ready to Install. (准备 安装 )” 对 话 框 ， 如 
图 1-11 所 示 。 





Ready to Install 





Setup is now ready to begin installing XAMPP on your computer. 





XAMPP Installer 








图 1-11 提示 开始 安装 










动态 网 站 开发 从 入 门 到 精通 





QL+Dreamweaver 


7) 再 单 击 “Next (下 一 步 )” 按 钮 ， 组 件 即 开始 安装 到 计算 机 上 ， 安 装 的 组 件 比较 多 ， 
大 小 近 1. 13 GB， 需 要 耐心 等 上 几 分 钟 ， 安 装 的 过 程 提 示 如 图 1-12 所 示 。 


(e Setup 


Welcome to XAMPP! 


XAMPP is an easy to install Apache distribution 
containing MySQL, PHP and Perl. 









Installing 
Unpacking files 








XAMPP Installer 











| < Back || Nest > | Cancel 


1-12. 安装 过 程 提 示 
8) 安装 完成 后 ， 会 弹出 “Completing the XAMMP Setup Wizard. ( 安 成 安装 ) ”对 话 框 ， 
进行 文件 的 最 后 确认 ， 如 图 1-13 所 示 ， 这 里 不 需要 进行 任何 操作 ， 单 击 “Do you want 
to start the Control Panel now? (开始 启动 管理 面板 )” 复 选 框 ， 可 以 启动 管理 面板 开始 
使 用 。 














(5 Setup 
p 





Completing the XAMPP Setup Wizard 


Setup has finished installing XAMPP on your computer. 











网 Do you want to start the Control Panel now? 











| < Back | Finish | Cancel 





图 1-13 完成 安装 对 话 框 


9) 单 击 “Finish (完成 )” 按 钮 之 后 ， 就 可 以 自动 启动 管理 面板 。 下 面 来 看 一 下 XAM- 
PP 的 控制 面板 如 图 1-14 所 示 。 








搭建 PHP 网 站 建设 平台 












































[- 
[E] XAMPP Control Panel v3.2.1 [ Compiled: May 7th 2013 ] bala 
XAMPP Control Panel v3.2.1 "Ir. 
Modules F: 
Service Module PID(s) Ports) Actions LL B Netstat 
| | Apache | Admin | [ Config Logs i Shell 
[55] MySQL Statt || Admin | |. Config Logs [ Explorer 
B FileZilla | Start | | Admin | Config | Logs | Semvices 
[ài] Mercury | Stat | | Admin | | Config J | Logs | & Help 
[23] Tomcat | Stat || Admin | Config | Logs | iB Quit 
10:08:07 [Apache] Attempting to start Apache app... a 


10:06:07 [Apache] Status change detected: running 
10:08:10 [mysql] Attempting to start MySQL app... 
10:08:14 [mysql] Status change detected: running 
10:06:18 [mysql] AÀttempting to stop MySQL (PID: 6272) 
10:06:19 [mysql] Status change detected: stopped 
10:06:19 [Apache] Attempting to stop Apache (PID: 5696) 
10:06:19 [Apache] Attempting to stop Apache (PID: 1464) 
10:08:20 [Apache] Status change detected: stopped 


m 




















1-14 XAMPP 的 控制 面板 


10) 单 击 面板 上 各 软件 组 件 后 面 的 Start 按钮 ， 开 启 Apache, MySQL 两 个 核心 程序 ， 最 
后 设置 完毕 的 对 话 框 如 图 1-15 所 示 。 图 中 ， 可 以 看 到 KAMPP 的 一 些 基 本 控制 功能 ， 注 意 
不 建议 把 这 些 功 能 注册 为 服务 (开机 启动 )， 每 次 用 到 时 再 启用 即 可 (桌面 上 已 经 有 图 标 )， 
这 样 在 不 使 用 XAMPP 时 更 节省 资源 。 








(TE) XAMPP Control Panel v3.21 [Compiled: May 7th 2013] mre 
XAMPP Control Panel v3.2.1 Jf Comis 
Modules [oec] 
Service Module PID(s) Port(s) Actions (detstatl 


| | Apache d 80,443 [ Stop || Admin || Config |[ Logs Bi Shell 





























| MySQL 7040 3306 [7Stop.] Admin | (Config ]( Logs | | Explorer | 

| | FileZilla | Stat ]| Admin | | Config || Logs | (HE Senices 
|] Mercury | Stat || Admin || Cong || Logs | ([.. Hep 

| | Tomcat [ Stat ][ Admin ][ Cong ][ Loss ] (Eau 
10:06:18 [mysql] Attempting to stop MySQL (PID: 6272) a; 


10:06:19 [mysql] Status change detected: stopped 
10:06:19 [Apache] Attempting to stop Apache (PID: 5696) 
5 [Àpache] Attempting to stop Apache (PID: 1464) 
[Apache] Status change detected: stopped 
[Apache] Attempting to start Apache app... 
[Apache] Status change detected: running 
[mysql] Attempting to start MySQL app... 
[nysq1] Status change detected: running 


m 


























图 1-15 启动 组 件 服务 
11) 启动 成 功 之 后 打开 IE 浏览 器 ， 输 入 服务 器 默认 IP 地 址 : 127.0.0.1, F (Enter) 


键 之 后 打开 如 图 1-16 所 示 的 欢迎 界面 ， 就 说 明 已 经 安装 成 功 可 以 开始 使 用 了 。 























GA - [E] http://127.0.0.1/xampp/splash.php 








XAMPP 





XAMPP 


English / Deutsch / Francais / Nederlands / Polski / Italiano / Norwegian / Español / 中 文 / Portugués (Brasil) / 日 本 语 


























这 里 要 特别 注意 的 是 : 





1-16 欢迎 界面 


对 初学 者 而 言 ， 开 发 后 的 PHP 网 站 程序 不 知道 要 放 在 哪里 。 其 实 很 简单 ， 只 要 将 整个 
网 站 程序 放 在 htdocs 文件 夹 下 即 可 进行 访问 ， 如 图 1-17 所 示 。 同 时 还 需要 将 数据 库 文件 放 
在 Mysql/data 文件 夹 下 ， 数 据 库 的 连接 用 户 名 命名 为 root， 密 码 为 空 (XAMPP 默认 安装 下 


的 用 户 名 和 密码 ) 。 


fi 
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L|: Creative Cloud 文件 


1j] Rubin 


AR 
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刻录 ”新 建文 件 夫 


Ljindexphp L forbidden 
|_] index.html |]; dashboard 
H favicon.ico 


it  bitnami.css 

| ]applications.html 
apache pb2 ani.gif 
18 apache pb2.png 
apache pb2.gif 
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图 1-17 网 站 所 放置 的 位 置 























D XAMPP 基本 使 用 方法 


XAMPP 安装 完成 之 后 ， 使 用 方法 如 下 : 





第 1 音 CEA 








1) XAMPP 的 启动 路 径 : xampp\xampp - control. exe, 

2) XAMPP 服务 的 启动 和 停止 脚本 路 径 。 

e 启动 Apache 和 MySQL: xampp\xampp_start. exe, 

e 停止 Apache 和 MySQL: xampp\xampp_stop. exe; > 
e 启动 Apache: xampp\apache_start. bat, 

e 停止 Apache: xampp\apache_stop. bat, 

e 启动 MySQL: xampp\mysql_start. bat, 

e 停止 MySQL: xampp Wmysgql. stop. bat, 

e 启动 Mercury 邮件 服务 髓 : xampp Wmnercury. start. bat, 

e iH FileZilla FTP 服务 器 : xampp Milezilla, setup. bat, 

e 启动 FileZilla FTP 服务 器 : xampp Milezilla, start. bat, 

e 停止 FileZilla FTP 服务 器 : xampp Milezilla, stop. bat. 

3) XAMPP 的 配置 文件 路 径 。 

€ Apache 基本 配置 : xampp\apache\conf\httpd. conf, 

® Apache SSL; xampp\apache \conf\ssl. conf, 

€ Apache Perl. ( 仅 限 搬 件 ) : xampp\apache\conf\perl. conf, 

* Apache Tomcat ( 仅 限 插件 ) : xampp apache \conf\java. conf, 

e Apache Python ( 仅 限 捅 件 ) : xampp\apache\conf\python. conf, 
e PHP: xampp\php\php. inis 

















e MySQL: xampp\mysql\bin\my. inio 

* phpMyAdmin; xampp\phpMyAdmin\config. inc. php; 

e FileZilla FTP 服务 器 : xampp VFileZillaFTP \ FileZilla Server. xml, 

* Mercury 邮件 服务 器 基本 配置 : xampp MercuryMail MERCURY. INI, 

e Sendmail; xampp sendmailNsendmail. ini 

4) XAMPP 的 其 他 和 常用 路 径 。 

e 网 站 根 目录 的 默认 路 径 : xampp\htdocs。 

e MySQL 数据 库 默 认 路 径 : xampp\mysql\data。 

5) 日 常 使 用 只 需要 使 用 XAMPP 的 控制 面板 即 可 随时 控制 Apache, PHP, MySQL 以 及 
FTP 服务 的 启动 和 终止 。 

6) 附 XAMPP 的 默认 密码 。 

e MySQL, 

User: root Password; ( 空 ) 

e FileZilla FTP。 


User; newuser Password; wampp 














User; anonymous Password; some@ mail. net 
* Mercury; 

Postmaster; postmaster ( postmasterQ localhost ) 
Administrator; Admin (admin@ localhost) 


TestUser: newuser Password; wampp 









PHP-«*MySQL Dreamweaver 


e WEBDAV, 

User; wampp Password; xampp 

参照 上 文 XAMPP 安装 和 配置 完成 后 ， 即 可 安装 Dreamweaver 等 网 页 程序 编辑 软件 进行 
网 页 编程 测试 了 。 


Apache 服务 器 的 安装 与 操作 


对 于 想 深 入 了 解 基础 环境 搭建 的 读者 可 以 学 习 本 小 节 以 后 的 内 容 。 如 果 是 初学 者 建议 在 
搭建 好 集成 环境 之 后 ， 直 接 开 始 第 2 章 的 学 习 。 基 于 Windows 操作 系统 支持 PHP 开发 的 服 
务 器 主要 有 TIS 和 Apache 两 款 ， 其 中 Apache 服务 器 是 专门 为 PHP 设置 的 解析 服务 器 ， 本 小 
节 重 点 介绍 Apache 服务 器 的 安装 和 设置 。 


is Apache 服务 器 基础 ) 


自从 PHP 发 布 之 后 ， 推 出 了 各 式 各 样 的 PHP 引擎 ， 最 为 经 典 的 配置 就 是 Apache 服务 
f. Apache 是 一 种 开源 的 HTTP 服务 器 软件 ， 可 以 在 包括 UNIX, Linux 以 及 Windows 在 内 的 
大 多 数 主流 计算 机 操作 系统 中 运行 ， 由 于 其 支持 多 平台 和 良好 的 安全 性 而 被 广泛 使 用 。 

Apache 作为 常 驻 的 后 台 任 务 运 行 ， 在 UNIX 系统 中 为 守候 进程 (Daemon), fE Windows 
系统 中 为 服务 (Service), HTF Apache 服务 器 的 启动 阶段 比较 耗费 时 间 和 资源 ， 因 此 它 一 般 
在 操作 系统 启动 时 被 启动 并 一 直 运 行 。 

Apache 的 运行 分 为 启动 阶段 和 运行 阶段 。 启 动 阶段 ，Apache 以 特权 用 户 root 启动 ， 进 
行 解析 配置 文件 、 加 载 模块 和 初始 化 一 些 系统 资源 (例如 ， 日 志文 件 、 共 享 内 存 段 、 数 据 
库 连 接 ) 等 操作 。 处 于 运行 阶段 时 ，Apache 放弃 特权 用 户 级 别 ， 使 用 非特 权 用 户 来 接收 和 
处 理 网 络 中 用 户 的 服务 请 求 。 这 种 基本 安全 机 制 可 以 阻止 Apache 中 由 于 一 个 简单 软件 错误 
(也 可 能 是 模块 或 脚本 ) 而 导致 的 严重 系统 安全 漏洞 ， 例 如 ， 微 软 的 HS 就 曾 遭 受 “ 红 色 代 
fij (Code Red) ”和 “ 尼 姆 达 (Nimda)” 等 恶意 代码 的 溢出 攻击 。 

Apache 的 主 配 置 文件 通常 为 httpd. conf。 但 是 由 于 这 种 命名 方式 为 一 般 惯例 ， 并 非 强 制 
要 求 ， 因 此 对 于 提供 rpm 或 者 deb 包 的 第 三 方 ，Apache 发 行 版 本 可 能 使 用 不 同 的 命名 机 制 。 
男 外 ，httpd. conf 文件 可 能 是 单一 文件 ， 也 可 能 是 通过 使 用 Include 指令 包含 不 同 配 置 文 件 的 
多 个 文件 集合 。 有 些 发 行 版 本 的 配置 非常 复杂 。httpd. conf 文件 是 一 个 文本 文件 ， 在 系统 启 
动 时 被 逐 行 解析 。 该 文件 由 指令 、 容 器 和 注释 组 成 。 配 置 文件 内 允许 有 空 行 和 空格 ， 它 们 在 
解析 时 被 忽略 不 计 。 


区 区 到 下 载 Apache 服务 器 


Apache 软件 和 其 他 免费 软件 一 样 ， 可 以 直接 到 其 官方 网 站 进行 下 载 ， 地 址 是 http://ht- 
tpd. apache. org/download. cgi。 下 载 Apache 的 最 新 版 本 步骤 如 下 : 
1) 打开 下 浏览 锅 ， 在 地 址 栏 输入 http: //httpd. apache. org/download. cgi 链接 至 Apache 
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N Download - The Apache ... X 








Essentials 


* About 

* License 

* FAQ 

* Security Reports 


Download! 





* From a Mirror 
Documentation 


* Version 2.4 
* Version 2.2 
* Version 2.0 


* Trunk (dev. 
* Wiki 


Get Support 
* Support 
Get Involved 


* Mailing Lists 
* Bug Reports 
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HTTP SERVER PROJECT 


Downloading the Apache HTTP Server 


Use the links below to download the Apache HTTP Server from one of our mirrors. You must verify the integrity of the downloaded files using 
signatures downloaded from our main distribution directory. 


Only current recommended releases are available on the main distribution site and its mirrors. Older releases, including the 1.3 family of releases, 
are available from the archive download site. 


Stable Release - Latest Version: 

- 24.7 (released 2013-11-25) 
Legacy Release - 2.2 Branch: 

* 2.2.26 (released 2013-11-18) 
Historical Release: 

* 2.0.65 (released 2013-07-09) 


If you are downloading the Win32 distribution, please read these important notes. 


The currently selected mirror is http://apache.dataguru.cn/. If you encounter a problem with this mirror, please select another mirror. If all mirrors 
are failing, there are backup mirrors (at the end of the mirrors list) that should be available. 
J TG 
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图 1-18 打开 的 官方 网 站 


2) 在 这 个 页 面 中 有 许多 下 载 选项 ， 为 了 方便 初学 者 进行 安装 ， 下 载 Apache 的 自动 安装 
程序 ， 单 击 选 择 页 面 上 的 “httpd —2.0.65 - win32 -x86 - no. ssl msi” 文 字 ， 如 图 1-19 


所 示 。 




















© [N rooted apacheorg/dounload.cgi 











N Download - The Apache ... X 





L9 ID 1 





* Binaries 
» Security and official patches 
* Other files 
Apache HTTP Server 2.0.65 Final is also available 2013-07-09 


Apache 2.0.65 is the final historical release of the 2.0 series, and is recommended over any previous 2.0 release. No further releases will occur, 
and all users are directed to install stable 2.4 or legacy 2.2 releases instead. This release fixes a few potential security vulnerabilites. 


For details see the Official Announcement and the CHANGES 2.0 and CHANGES 2 0.65 lists. 





Apache 2.0 add-in modules are not compatible with Apache 2.2 modules. If you are running third party add-in modules, you will need to obtain 
modules compiled for or compatible with Apache 2.0 from that third party, before you attempt to use this specific release. 


* Source: httpd-2 0.65 tar.gz [ PGP ] | MD5] 
* Source: httpd-2 0.65.tar.bz2 [ PGP ]  MD5] 


* Win32 Source: httpd-2 0.65-win32-src zip [ PGP ] [MD5] 








* Win32 Binary without crypto (no mod ssl) (MSI Installer): Ë [PGP ][ MD5] [SHA1] 





* Win32 Binary including OpenSSL 0.9.8y (MSI Installer): httpd-2.0.65-win32-x86-openssl-0 9 8y.msi [ PGP ] [MD5] [SHA1] 





* NetWare Binary: apache 2.0.65-netware zip [ PGP ] [ MD5 ] [ SHA1 ] 





* Security and official patches 


* Other files 














http:;//mirrors.cnnic.cn/apache//httpd/binaries/win32/httpd-2.0.65-win32-x86-no ssl.msi 








vache HTTP Server released as 2.3.9 2013-10-08 
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图 1-19 选择 相应 的 文件 下 载 
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RE 安装 Apache 服务 器 


完成 下 载 Apache 的 安装 程序 后 ， 双 击 下 载 的 可 执行 安装 文件 ， 如 图 1-20 所 示 。 


r 





O- Lo» 计算 机 » ARSD) » PHP ， soft » 
; 文件 (F) SSE EEV) IAM) =H) 
组 织 ” Psr aa 新疆 文件 夫 
^ 名称 











A 


LE S 


Dreamweaver 14 LS20.exe 2014/12/6 20:06 应 用 程序 

(9 httpd-2.0.65-win32-x86-no ssl.msi 2013/12/31 15:29 Windows Install... 

SB il mysql-installer-community-5.6.15.0 (L... 2013/12/31 19:50 Windows Install... 
& Acer (C) dB) php-5.3.28-Win32-VC9-x86.msi 2013/12/31 16:10 Windows Install... 
cas 本 地 磁盘 (D:) $È phpMyAdmin-4.1.3-alllanguages.zip 2014/1/1 10:37 WinRAR ZIP 压缩 .… 
ca 本 地 磁盘 (E:) —, WX xampp-win32-5.6.3-0-VC1i-installer.e.. 2015/1/15 9:39 应 用 程序 








EE 
ji DOUGLAS-PC 
ji PC-20141030EJVK 





httpd-2.0.65-win32-x86-no ssl.msi 修改 日 期 : 2013/12/31 15:29 创建 日 期 : 2015/1/15 10:26 
Windows Installer 程序 包 大 小 : 4.84 MB 











1-20 下 载 的 Apache 安装 文件 包 


安装 的 步骤 如 下 : 
1) 双击 安装 文件 包 ，Apache 安装 精灵 会 提示 将 安装 Apache 服务 器 ， 并 有 和 警告 信息 ， 如 
图 1-21 所 示 。 





65 
39) Apache HTTP Server 2.0 - Installation Wizard 


Welcome to the Installation Wizard for 
Apache HTTP Server 2.0.65 


The Installation Wizard will install Apache HTTP Server 2.0.65 
on your computer. To continue, dick Next. 


WARNING: This program is protected by copyright law and 
international treaties. 

















K 1-21 欢迎 安装 界面 





JUN 
设 平台 





2) 单 击 Ce ] 按钮 ， 继 续 安 装 程序 。 选 中 “TI accept the terms in the license agreement 
(我 接受 告知 条 款 上 的 内 容 )” 单 选 按钮 同意 合约 的 授权 ， 继 续 进 行 安 装 ， 如 图 1-22 所 示 。 





而 
J) Apache HTTP Server 2.0 - Installation Wizard 


License Agreement 


Please read the following license agreement carefully. 








Apache License 
Version 2.0, January 2004 
http:l/www.apache.org/licenses! 
TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION 
1. Definitions. 


"License" shall mean the terms and conditions for use, reproduction, and 
distribution as defined by Sections 1 through 9 ofthis document. 


@ I accept the terms in the license agreement 
© I do not accept the terms in the license agreement 


InstallShield 











1-22 同意 安装 


3) Hub we 按钮， 继续 安装 程序 ， 打 开 “Read This First. (〈 预 读 下 面 内容 ) ”对话 框 ， 
如 图 1-23 所 示 。 





[- 
J) Apache HTTP Server 2.0 - Installation Wizard 


Read This First 
Read this Before Running Apache on Windows. 





Apache HTTP Server 


What is it? 

The Apache HTTP Server is a powerful and flexible HTTP/1.1 compliant web server. 
Originally designed as a replacement for the NCSA HTTP Server, it has grown to be 
the most popular web server on the Internet. As a project ofthe Apache Software 
Foundation, the developers aim to collaboratively develop and maintain a robust, 


commercial-grade, standards-based server with freely available source code. 


The Latest Version 
Details ofthe latest version can be found on the Apache HTTP server project page 
under: 


http-//httpd.apache.orq/ 


InstallShield 











1-23 “Read This First ( 预 读 下 面 内容 )” 对 话 框 


4) Æ “Read This Firsr ( 预 读 下 面 内 容 )” 对 话 框 中 主要 是 介绍 Apache HTTP Server 
(Apache 网 页 服务 器 ) 的 一 些 基础 知识 ， 初 次 使 用 的 读者 可 以 认真 了 解 一 下 ， 以 方便 进一步 
AER], Hh] wes 按钮， 打开 “Server Information. (服务 器 信息 )” 对 话 框 ， 自 行 设 定 服务 
器 和 域名 名 称 ， 并 要 输入 管理 者 的 联系 邮箱 。 如 图 1-24 所 示 。 
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而 
划 Apache HTTP Server 2.0 - Installation Wizard 


Server Information 


Please enter your server's information. 





Network Domain (e.g. somenet.com) 
[pheserver 


Server Name (e.g. www.somenet.com): 


phpserver 





Administrator's Email Address (e.g. webmaster &somenet.com): 


83560148 (8qq.com 


Install Apache HTTP Server 2.0 programs and shortcuts for: 


(Q^ for All Users, on Port 80, as a Service -- Recommended. 
© only for the Current User, on Port 8080, when started Manually. 


InstallShield 











E 











Til 


图 1-24 “Server Information (服务 器 信息 )” 对 话 村 
5) 设 定 完成 后 ， 再 单 击 CE 按钮 ， 继 续 进行 下 一 步 安装 。 打 开 “Setup Type (安装 类 


型 ) ”对 话 框 ， 这 里 有 Typical (典型 ) 和 Custom (HEX) 安装 两 个 单 选项 ， 如 图 1-25 
所 示 。 








而 
39) Apache HTTP Server 2.0 - Installation Wizard 


Setup Type 
Choose the setup type that best suits your needs. 


Please select a setup type. 





© Typical 
Typical program features will be installed. (Headers and Libraries 
for compiling modules will not be installed.) 


Choose which program features you want installed and where they 
will be installed. Recommended for advanced users. 





InstallShield 




















图 1-25 “Setup Type (安装 类 型 ) ”对 话 框 





6) 选中 “Custom ( 自 定义 )” 单 选 按 钮 ， 再 单 击 Cuex>_ |] 按钮， 打开 “Custom Setup ( H 
定义 安装 内 容 )” 对 话 框 ， 如 图 1-26 所 示 。 这 里 将 选择 所 有 的 内 容 进行 安装 对 话 框 ， 以 方 
便 后 面 PHP 程序 的 开发 应 用 需要 ， 由 于 Apache 预 设 的 路 径 有 点 长 ， 为 了 方便 起 见 ， 本 书 将 
安装 路 径 改 成 C:\Apache， 单 击 “Change (改变 ) ”按钮 ,将 服务 器 的 安装 路 径 设 置 为 
C:\Apache\, 











全 - 
3) Apache HTTP Server 2.0 - Installation Wizard 区 本 


Custom Setup 
Select the program features you want installed. 


Click on an icon in the list below to change how a feature is installed. 
Feature Description 
The Apache HTTP Web Server 

















i- E v | Build Headers and Libraries 
i ^ E v | APR Iconv Code Pages 
E — > | Apache Documentation 
This feature requires OKB on 
your hard drive. It has 2 of 2 
subfeatures selected. The 
subfeatures require 35MB on 
your hard drive. 











Install to: 


C:Mpachel Change... 


InstallShield 


























[ Hep  ][ see |[ «s&« Next > Cancel 








É 1-26 “Custom Setup (〈 自 定义 安装 内 容 ) ”对话 框 











7) Hub wes Pth, JJF “Ready to Install the Program. (准备 安装 ) ”对 话 框 ， 如 图 1-27 


所 示 。 








P - 
3l Apache HTTP Server 2.0 - Installation Wizard [x 





Ready to Install the Program 
The wizard is ready to begin installation. 


Click Install to begin the installation. 


If you want to review or change any of your installation settings, click Back. Click Cancel to 
exit the wizard. 








InstallShield 
































Hil 





图 1-27 “Ready to Install the Program. (准备 安装 )” 对 话机 





按钮 ， 开 始 进行 具体 的 安装 ， 安 装 过 程 如 图 1-28 所 示 。 





6 
3) Apache HTTP Server 2.0 - Installation Wizard 





Installing Apache HTTP Server 2.0.65 
The program features you selected are being installed. 





A] Please wait while the Installation Wizard installs Apache HTTP Server 
[sF 20.65. This may take several minutes. 

Status: 

Copying new files 


= = c- 3 











InstallShield 
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9) 安装 完成 后 ， 单 击 L_ es 按钮， 如 图 1-29 所 示 。 


[4 
39) Apache HTTP Server 2.0 - Installation Wizard 





Installation Wizard Completed 


The Installation Wizard has successfully installed Apache HTTP 
Server 2.0.65. Click Finish to exit the wizard. 














图 1-29 ”完成 安装 


到 此 Apache 服务 器 的 安装 步骤 就 完成 了 。 这 里 在 完成 安装 的 时 候 要 注意 所 使 用 的 操作 
系统 端口 80 不 能 被 占用 ， 如 果 计 算 机 上 默认 安装 了 IIS 并 已 经 占用 了 80 端口 ， 那 么 需要 将 
其 禁用 才能 安装 成 功 。 


ER Apache 服务 器 操作 


安装 完成 Apache 服务 器 后 ， 首 先 要 测试 一 下 前 面 的 安装 与 设 定 是 否 成 功 。 由 于 是 在 本 
地 计算 机 安装 Apache 服务 器 ， 因 此 它 的 HTTP 地 址 的 预 设 路 径 是 http ://localhost。 

首先 打开 IE 浏览 器 ， 在 地 址 栏 输入 http://localhost， 如 果 能 顺利 开启 如 图 1-30 所 示 的 
网 页 画面 ， 就 表示 Apache 服务 器 服务 成 功 启 动 了 。 


























GE http;//localhost/ 












您 能 看 见 这 个 页 面 ， 说 明 Apache web server 已 经 安装 成 功 。 您 可 以 在 这 个 目录 中 增加 内 容 ， 或 者 把 这 个 页 面 替 换 掉 。 


这 不 是 你 想 看 见 的 页 面 吧 ? 


之 所 以 会 看 见 这 个 页 面 ， 是 因为 网 站 管理 员 改 变 了 这 个 站 点 的 设置 。 如 果 有 疑问 ， 请 咨询 维护 此 站 点 的 人 员 。 Apache 软 件 基金 会 ， 即 此 站 点 所 使 用 的 网 站 服 
务 器 软件 的 开发 者 ， 不 负责 此 站 点 的 维护 工作 ， 也 无 法 为 您 解决 设置 上 的 问题 





Apache 文档 已 经 包含 在 此 发 行 版 中 。 
您 可 以 在 使 用 Apache 的 网 站 服务 器 上 ， 自 由 地 使 用 下 面 的 图 片 。 感 谢 使 用 Apachel 
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1-30 测试 成 功 页 面 
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Apache 服务 器 的 服务 ， 对 PHP 网 页 的 执行 有 很 重要 的 关联 ， 因 此 接 下 来 要 说 明 Apache 
服务 器 的 设 定 与 操作 。 
1. Apache 服务 器 的 启动 


当 在 Apache 服务 需 安 装 完成 的 页 面 上 ， 已 经 匀 选 “for All User, on Port 80, as a Service 
- Recommended. ”的 选项 ， 那 么 Apache 就 已 经 自动 启动 。 可 以 在 Windows 程序 列表 上 发 现 


多 了 一 个 网 标 辆 。 
如 果 Apache 服务 需 停 止 服 务 后 要 再 启动 Apache kiir, YE Windows 系统 图 标 中 的 贺 图 
标 上 单 击 鼠标 右键 ， 弹 出 快捷 菜单 ， 再 选择 “Start (开始 )” 选 项 就 可 以 重新 启动 Apache 
服务 器 的 服务 。 
2. Apache 服务 器 的 停止 


如 果 要 停止 Apache 服务 器 ,在 Windows 系统 图 标 中 的 责 网 标 
上 单 击 鼠 标 右键 弹出 快捷 菜单 ， 只 要 选择 “Stop (停止 )” 选 项 就 
可 以 停止 Apache 服务 器 的 服务 ; 这 时 ，Apache 的 系统 图 标 变 成 


B, Anl 1-31 所 示 。 
3. Apache 服务 器 的 主 目录 
EWM F, Apache 服务 器 主 目录 的 预 设 位 置 在 C:\Program Files \ Apache Software 
Foundation \ Apache 路 径 下 。 由 于 前 面 安 装 时 将 Apache 服务 吉安 装 在 C:\Apache 文件 夹 中 ， 
因此 主 目 录 也 在 C:\Apache 路 径 下 ， 打 开 的 二 级 目录 如 图 1-32 所 示 。 











Start 


Restart 


1-31 停止 操作 界面 



































































per) 
(CION bor 计算 机 » Acer (C) » Apache p Apache2 » X [| | 485 Apache2 p 
组 织 Y 包含 到 库 中 v 共享 刻录 新 建文 件 夫 s- m @ 
PEE 名 称 修改 日 期 类 型 大 小 
jj TE J bin 2013/12/31 15:36 
m sm |: cgi-bin 2013/12/31 15:36 
5 最 后 访问 的 位 置 E conf 2013/12/3 36 
b error 2013/12/3 36 
司库 I htdocs 2013/12/31 15:36 
I icons 2013/12/31 15:36 
H ig |; include 2013/12/31 15:36 3 
图 图 片 i lib 2013/12/31 15:36 ”文件 去 
D xe I logs 2013/12/31 15:36 Vi 
"EI Ji manual 2013/12/31 15:36 。 文件 志 
I modules 2013/12/31 15:36 ”文件 去 
m 计算 机 Ji proxy 2013/12/31 15:36 
& Acer (C) 国 ABOUT. APACHE 2004/11/24 14:31 15 KB 
ca 本 地 磁盘 (D) 国 CHANGES 2013/6/26 19:10 326 KB 
cs HERS (E) E] INSTALL 2012/1/17 17:54 4 KB 
Ej ucENSE 2013/7/9 21:38 6 KB 
ana E NOTICE 2013/7/9 21:38 2 KB 
国 README 2007/1/10 0:50 6 KB 
| 18 个 对 象 
J 














图 1-32 打开 的 文件 夹 目 录 


Apache 服务 器 各 主要 目录 的 意义 与 用 途 说 明 如 表 1-1 所 示 。 
4. Apache 服务 器 的 网 站 目录 
Apache 服务 器 安装 完成 后 ， 需 要 将 所 有 PHP 网 站 目录 都 放 到 C:/Apache/Apache 2/ 









态 网 站 开发 从 入 门 到 精通 





PHP+MYSQL+Dreamweaver x 


htdocs 文件 夹 内 。 例 如 ， 写 了 一 个 名 为 website 的 PHP 网 站 目录 ， 则 这 个 website 的 网 站 目录 
位 置 应 该 放 到 C:\Apache\Apache 2\htdocs\ 的 文件 夹 中 。 当 然 也 可 以 直接 打开 httpd. conf X 
件 ， 找 到 如 图 1-33 所 示 的 位 置 ， 将 ServerRoot " C;/Apache/Apache2" 这 一 行 代码 进行 相应 
的 设置 即 可 更 改 为 新 的 网 站 目录 。 
表 1-1 Apache 安装 文件 夹 说 明 

文件 夹 名 称 主要 功能 

bin 储存 编译 程序 及 指令 文件 。 

cgi - bin 储存 用 于 设置 支持 egi 的 文件 。 

conf 储存 服务 器 结构 档案 ，httpd. conf 文件 是 设置 服务 器 的 主要 文件 。 

error 储存 运行 出 错时 提示 用 的 文件 。 

hidocs 储存 运行 成 功 时 显示 的 文件 ， 该 版 本 只 有 简单 的 一 行 字 。 

icons 储存 服务 器 显示 相应 网 页 的 所 有 图 片 文件 。 

include 储存 支持 服务 器 的 一 些 主要 包含 文件 。 

lib 储存 Apache 所 需 的 lib 文件 。 

logs 储存 日 志 档 案 。 

manual 储存 服务 器 的 模块 功能 文件 。 

modules 储存 网 页 应 用 程序 的 目录 。 

































































可 hapd -记事 本 eI) 
文件 (月 ”编辑 (E) ERO EEV) ”帮助 (H) 


# at XURL:http://httpd. apache. org/docs/2. 0/mod/mpm_common. html#lockfile>); ^ 
# you will save yourself a lot of trouble. 








# Do NOT add a slash at the end of the directory path. 


# 
IServerRoot "C: /Apache/Apache2^ 


# 

# ScoreBoardFile: File used to store internal server process information. 
# If unspecified (the default), the scoreboard will be stored in an 

# anonymous shared memory segment, and will be unavailable to third-party 
# applications. 

# If specified, ensure that no two invocations of Apache share the same 
# scoreboard file. The scoreboard file MUST BE STORED ON A LOCAL DISK. 


iScoreBoardPFile logs/apache runtime status 


# PidFile: The file in which the server should record its process 
# identification number when it starts. 


PidFile logs/httpd.pid 


# Timeout: The number of seconds before receives and sends time out. 


Timeout 300 














# 
# KeepAlive: Whether or not to allow persistent connections (more than 








图 1-33 设置 网 站 文件 位 置 
进行 到 此 ， 已 经 完成 了 PHP 网 页 开发 环境 Apache 服务 器 的 安装 。 
PHP 的 安装 与 配置 


在 计算 机 上 安装 完成 Apache 服务 器 后 ， 就 要 开始 安装 和 配置 PHP 的 执行 环境 ，PHP 的 
安装 与 配置 有 多 种 方法 ， 这 里 介绍 使 用 PHP 官方 提供 的 安装 包 来 进行 安装 的 方法 。 















第 1 


ETIN 下 载 PHPS 软件 | 


安装 好 Apache 服务 器 以 后 ， 下 面 开始 安装 PHP。PHP 开发 软件 包 是 开发 PHP 程序 的 核 > 
心 ， 该 软件 包 需 要 从 PHP 官方 网 站 下 载 ， 地 址 为 http://www. php. net。 这 里 以 PHP 5. 3. 28 
版 本 为 例 ， 下 载 的 页 面 如 图 1-34 所 示 。 





2 €A 


























| & http://windows.php.net/download/ D-&ROÓX|AM u i9: 








@ PHP For Windows: Binari.. x 
performance (old) 





VC9 x86 Non Thread Safe (2013-Dec-12 01:58:52) 
x86 64 Builds 
The x64 builds of PHP for a Zip [16.24MB] 
Windows should be considered 
experimental, and do not yet 





shal: 84013dd4b96bc456953f780d4ea329acc3455d06 


provide 64-bit integer or large file 
support. Please see this post for 
work ongoing to improve these shal: 8411eaa51b7effed861456097178bb9fc4907b3e 


builds. 


mw Installer [45.74MB] 





m Debug Pack [8.36MB] 
shal: dbc548494f193683250132bb2af4f15b0606ef1a 





Archives VC9 x86 Thread Safe (2013-Dec-12 01:59:01) 

Past releases are available from 

our archives, older versions not a Zip [16.38M8] 

found there can be found at the shal: fa7e8fGeBbff442e0e0b1889f52e0c3b93a84b2b 


Museum. 
w Installsy [45.86MB] 
shal: 24bba26bbf8b605b18fdbd9bd0b6412558a20f6f 


m Debug Pack [8.79MB] 
shal: 2cd638738adcef9f20c4b4bd95f2581e98256030 















1 分 钟 40 秒 EFP) 取消 (QO 童 看 下 载 (V) 























http://windows.php.net/downloads/releases/php-5.3.28-Win32-VC9-x86.msi 





1-34 F PHP 安装 版 本 


PHP 5. 3. 28 有 None Thread Safe 与 Thread Safe 两 种 版 本 可 供 选择 。 这 两 种 版 本 有 何不 
同 ， 作 为 使 用 者 来 说 又 应 该 如 何 选 择 呢 ?” 先 从 字面 意思 上 理解 ，None Thread Safe 就 是 非 线 
程 安全 ， 在 执行 时 不 进行 线程 (thread) 安全 检查 ; Thread Safe 就 是 线程 安全 ， 执 行 时 会 进 
行 线程 (thread) 安全 检查 ， 以 防止 有 新 要 求 就 启动 新 线程 的 CGI 执行 方式 耗 尽 系统 资源 。 
再 来 看 PHP 的 两 种 执行 方式 : ISAPI 和 FastCGI, FastCGI 执行 方式 是 以 单一 线程 来 执行 操 
作 ， 所 以 不 需要 进行 线程 的 安全 检查 ， 除 去 线程 安全 检查 的 防护 反而 可 以 提高 执行 效率 ， 所 
以 ， 如 果 是 以 FastCGI (无 论 搭 配 DIS 6 或 IIS 7 以 及 更 高 版 本 ) 执行 PHP ， 都 建议 下 载 、 执 
fT Non Thread Safe 的 PHP (PHP 的 二 进 制 文档 有 两 种 包装 方式 : msi 、zip ， 请 下 载 zip 套 
件 ) 。 而 线程 安全 检查 正 是 为 ISAPI 方式 的 PHP 准备 的 ， 因 为 有 许多 PHP 模块 都 不 是 线程 安 
全 的 ， 所 以 需要 使 用 Thread Safe 的 PHP。 本 书 是 使 用 Apache 服务 器 ， 所 以 要 选择 VC9 版 本 
的 Thread Safe 这 个 PHP 来 安装 。 








IL 安装 PHPS 软件 


下 载 后 即 可 以 开始 PHP 的 安装 ， 具 体 的 安装 步骤 如 下 : 
(1) 双击 下 载 的 文件 php -5. 3. 28 - win32- installer. msi， 弹 出 PHP 安装 程序 欢迎 安装 向 
导 对 话 框 ， 如 图 1-35 所 示 。 











动态 网 站 开发 从 入 门 到 精通 





Welcome to the PHP 5.3.28 Setup Wizard 


The Setup Wizard will install PHP 5.3.28 on your computer. 
Click Next to continue or Cancel to exit the Setup Wizard. 
Please disable any virus detection software you may have 
running during this installation. 











图 1-35 欢迎 安装 界面 


(2) 单 击 [ Nex JIZ, FIIF “End - User License Agreement (终端 用 户 许 可 )” 对 话 
JE, XF “I accept the terms in the license Agreement” 复 选 框 ， 同意 合约 的 授权 ， 继 续 进行 
安装 ， 如 图 1-36 所 示 。 





而 
JH) PHP 5.3.28 Setup 


End-User License Agreement 
Please read the following license agreement carefully 





The PHP License, version 3.01 
Copyright (c) 1999 - 2010 The PHP Group. All rights 


Redistribution and use in source and binary forms, 
with or without 
modification, is permitted provided that the 








V |I accept the terms in the License Agreement 














mk Jer) (Gm) 








图 1-36 同意 安装 


(3) "hi [ wee jj 按钮， 打开 “Destination Folder (安装 路 径 文件 )” 对 话 框 ， 单 击 
Browse (浏览 ) 按钮 来 更 改 PHP 的 安装 路 径 ， 这 里 为 “C:\PHP\” 目 录 ， 如 图 1-37 所 示 。 

(4) 设置 PHP 安装 路 径 之 后 ， 单 击 [_ nex 按钮， 选择 安装 的 Apache 版 本 号 ， 这 里 为 
Apache 2. 2x Module, ， 如 图 1-38 所 示 。 

(5) Hh l rt PRH, RE Apache 服务 器 的 安装 路 径 ， 如 图 1-39 所 示 。 

(6) 然后 单 击 [_ ex Ht, IIF “Choose Items to Install. (选择 安装 项 目 ) ”对话 框 ， 
选择 要 安装 的 PHP 组件， 设置 如 图 1-40 所 示 。 


)906006060€6€5*.:00000( 
q 





» 6 00 


e e0 00004 









f 
39) PHP 5.3.28 Setup m= 


Destination Folder 
Click Next to install to the default folder or dick Browse to choose another. 





Install PHP 5.3.28 to: 

















1-37 设置 安装 路 径 





而 
JH PHP 5.3.28 Setup 


Web Server Setup 
Select the Web Server you wish to setup. 





(9) Apache 2.2.x Module 

(C) Apache CGI 

© IIS FastCGI 

(C) IIS CGI 

© NSAPI 

© Xitami 

© NetServe Web Server 

(C) Other CGI 

© Do not setup a web server 











Kd 1-38 选择 Apache 版 本 号 








[^ 
JË) PHP 5.3.28 Setup. pex qn 


Apache Configuration Directory 
Browse to select the directory containing the Apache Configuration Files (c... 





Apache Configuration Directory: 


[c MpacheMpache2| 











E 1-39 设置 Apache 服务 器 安装 路 径 
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[t 


& 
划 PHP 5.3.28 Setup pee 


Choose Items to Install 
Select the way you want features to be installed. 


Click the icons in the tree below to change the way features will be installed. 

















L. X ~| Multi-Byte St (8j 


This feature requires 36KB on your 
hard drive. 




































DS 











1-40 选择 需 安装 的 PHP 组件 





特别 说 明 : 

在 安装 的 时 候 一 定 要 展开 PHP 的 列 选项 ， 选 择 MySQL 的 组 件 ， 这 样 才能 把 PHP 和 
MySQL 数据 库 关 联 起 来 ， 以 方便 进一步 的 数据 库 连 接 使 用 。 

(7) RERE Ah nt Hth, FTIF “Ready to install PHP5. 3.28 (准备 安装 )” 对 
话 框 ， 如 图 1-41 所 示 。 





f 


Fr 
划 PHP 5.3.28 Setup per 


Ready to install PHP 5.3.28 Lpnpy 


Click Install to begin the installation, Click Back to review or change any of your 
installation settings. Click Cancel to exit the wizard. 























图 1-41 准备 安装 对 话 框 


(8) Hub[ ma 按钮 安装 PHP， 安 装 过 程 中 会 有 安装 进度 提示 ， 如 图 1-42 所 示 。 

(9) 安装 完成 后 会 显示 完成 对 话 框 ， 提 示 成 功 安装 了 PHP 软件 包 ， 单 击 CEs WES SE 
成 安装 。 如 图 1-43 所 示 。 

(10) 这 是 最 关键 的 一 步 ， 需 要 将 安装 后 的 C:\PHP\ext 文件 夹 下 的 驱动 文件 都 复制 到 
C: \WINDOWS \system32 文件 夹 下 。 

如 果 读 者 在 PHP 官方 网 站 下 载 的 PHP 软件 包 是 非 安 装 程序 而 是 压缩 包 ， 那么 在 配置 时 














jos SE 





6G 
划 PHP 5.3.28 Setup 


Installing PHP 5.3.28 





Please wait while the Setup Wizard installs PHP 5.3.28. 





Status: 
l 








[ Bak ] Net - 

















图 1-42 ”安装 过 程 











c 
39) PHP 5.3.28 Setup 


Completed the PHP 5.3.28 Setup Wizard 


Click the Finish button to exit the Setup Wizard. 





Cancel 














图 1-43 ”完成 安装 








需要 设置 环境 变量 。 具 体 设置 环境 变量 的 方法 
WF: [an “| 计算机 名 | 硬件 高 大 [XUI | 自动 更 新 | 远程 

首先 将 PHP 压缩 包 解 压 到 指定 文件 夹 中 
作为 PHP 的 根 目录 , 例如 “C:\PHP” 目 录 
中 。 然 后 再 配置 Apache 运行 时 需要 加 载 的 
php5apache2_2. dll 文件 。 方 法 是 将 PHP 的 安 : SystenRootW\ systen32: NSyst, 
装 路 径 追 加 到 Windows 系统 中 Path 路 径 的 下 
面 。 右 击 “ 我 的 电脑 ”， 选 择 “ 属 性 ”命令 ， CE 
在 弹出 的 “系统 属性 ”对 话 框 中 切换 到 “高 


























系统 变量 (3) 




















变量 
级 ” 选项 卡 ， 再 单 击 « 环境 变量 Eh» 按钮 ， 打 pte CIDONS ers ms2 m exe 
开 “环境 变量 量 ” 对 话 框 。 人 RE 变量 ” 列 E Tidone oa Es oy 
表 中 找到 Path 路 径 ， 单 击 “ 编 辑 ” 按 钮 后 uie ELEM 
在 弹出 对 话 框 的 “变量 值 ”文本 框 中 将 “C 
\PHP” 追加 到 路 径 中 即 可 ， 如 图 1-44 所 示 。 





图 1-44 “编辑 系统 变量 ”对 话 框 设置 
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o 配置 Apache 支持 PHP 


安装 完成 PHP 后 ， 并 不 能 直接 在 Apache 里 运行 PHP 文件 ， 还 要 进一步 配置 一 下 A- 
pache 才 可 以 支持 PHP 的 运行 。 配 置 的 方法 很 简单 ， 步 又 如 下 : 
1) 进入 Apache 服务 器 的 安装 文件 夹 ， 如 图 1-45 所 示 。 

















组 织 ”包含 到 库 中 v 共享 " 刻录 FEHR 


PUE z s 修改 日 期 aem 
见 下 载 j bi 2013/12/31 15:36 ”文件 夫 
mu 上 cgi-bin 2013/12/31 15:36 — 文件 夫 
35 SaN ll conf 2013/12/31 16:18 ”文件 夫 
error 2013/12/31 15:36 X 
htdocs 2013/12/31 15:36 ”文件 去 
icons 2013/12/31 15:36 ”文件 去 


b 
b 
aE 
b 
L include 2013/12/31 15:36 X 
b 
by 
b 
b 


Bun 
ij B 
Bx 
d ER 


lib 2013/12/31 15:36 Xx 
logs 2013/12/31 15:36 Xx 
manual 2013/12/31 15:36 ”文件 去 
modules 2013/12/31 15:36 Xx 
IU 计算 机 ) proxy 2013/12/31 15:36 ”文件 去 
Ë Acer (C) 国 ABOUT. APACHE 2004/11/24 14:31 ”文本 文档 
c 本 地 磁盘 (D:) Lj CHANGES 2013/6/26 19:10 文本 文档 
ca 本 地 磁盘 (E) L| INSTALL 2012/1/17 17:54 文本 文档 
Lj LICENSE 2013/7/9 21:38 文本 文档 























图 1-45 进入 Apache 服务 器 的 安装 文件 夹 


2) 双击 进入 conf HK, FIF httpd. conf 文件 ， 在 文件 的 最 下 方 增加 下 面 1 行内 容 ， 如 

图 1-46 所 示 。 
AddType application/x - httpd ~ php . php 

该 段 代 码 中 , 第 1 行 : PHPImiDir"C:\PHP\" 表示 要 加 载 的 模块 在 哪个 位 置 存储 。 

第 2 ÍT: LoadModule php5 module"C:\PHP\php5apache2_2. dll" 表示 PHP 所 在 的 初始 化 
路 径 。 

第 3 fi; AddType application/x - httpd — php. php 表示 将 一 个 MIME 类 型 绑 定 到 某 个 或 某 
些 扩展 名 。. php 只 是 一 种 扩展 名 ， 这 里 可 以 设 定 为 . html, . php2 等 。 

此 时 PHP 环境 就 配置 完成 了 。 

3) 同样 查找 DirectoryIndex 这 个 代码 : 将 其 后 面 的 代码 改 为 如 下 。 


DirectoryIndex index. php default. php index. html 
表示 默认 访问 站 点 时 打开 的 首页 顺序 是 index. php default. php index. html, 


TI | 搭建 PHP 网 站 建设 平台 








( 73 hipa - igi 
ZÐ RAO 格式 (O) EEV) 帮助 (H) 


ü 
# You may use the command line option '-S' to verify your virtual host 
# configuration. 





# Use name-based virtual hosting. 


HNameVirtualHost *:80 


# 

# VirtualHost example: 

# Almost any Apache directive may go into a VirtualHost container. 

# The first VirtualHost section is used for requests without a known 
# server name. 


# 

#<VirtualHost *:80> 

# Serverådmin webmasterüdummy-host. example. com 

# DocumentRoot /www/docs/dummy-host. example. com 

# ServerName dummy-host. example. com 

# ErrorLog logs/dummy-host. example. com-error log 

# CustomLog logs/dummy-host. example. com-access_log common 
#</VirtualHost> 


#BEGIN PHP, INSTALLER EDITS - REMOVE ONLY ON UNINSTALL 
PHPIniDir "C: daa 
phpbapache2, 2. dll^ 


D d-php .php 
SEND "PHP INSTALLER EDITS - REMOVE ONLY ON UNINSTALL 











E 











1-46 加 入 支持 PHP 的 代码 


C o 测试 PHP 环境 


PHP 软件 包 安装 完成 后 ， 就 可 以 在 Apache 中 测试 PHP 环境 是 否 正确 了 。 下 面 创建 一 个 
PHP 示例 来 测试 ， 该 示例 是 执行 一 个 带 有 PHP 脚本 的 程序 ， 如 果 执 行 成 功 ， 则 证 明 PHP 安 
装 成 功 。 打 开 Apache 下 的 htdocs 目录 (这 里 为 C:\Apache\Apache2 \htdocs) ， 然 后 使 用 记事 
本 创建 一 个 名 为 test php 的 文件 ， 再 添加 如 下 代码 到 文件 中 。 


<? php 
phpinfo( ) ; /输出 PHP 环境 信息 








7» 


保存 test. php 文件 ， 然 后 在 正 浏览 器 的 地 址 栏 中 输入 “http://localhost/test. php" , 40 
果 显 示 PHP 的 相关 信息 ， 则 证 明 PHP 软件 包 和 环境 配置 成 功 。 如 图 1-47 所 示 ， 和 否则 安装 
失败 。 

特别 说 明 : 

本 书 第 1 版 有 很 多 读者 反馈 装 到 这 一 步 的 时 候 运行 不 了 ， 主 要 是 因为 安装 系统 和 环境 
同 的 结果 ， 为 了 解决 这 一 问题 ， 建 议 初学 者 使 用 集成 环境 ， Morc Me i 
PHP+PERL) 。 由 于 刚才 在 前 面 重 新 配置 了 Apache 服务 器 ， 所 以 在 测试 之 前 一 定 要 重启 
Apache 服务 器 ， 让 配置 的 功能 能 够 正确 地 被 使 用 。 
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pere 
GEI ntp7/127.0.01/test.php D-BOX| i ve i9 
phpinfo() 
l 
System Windows NT DOUGLAS-PC 6.1 build 7601 (Windows 7 Home Basic Edition Service 
Pack 1) i566 
Build Date Nov 12 2013 11:29:52 
Compiler MSVC11 (Visual C++ 2012) 
Architecture x86 
Configure cscript /nologo configure.js "--enable-snapshot-build" "--disable-isapi" "--enable- 
Command debug-pack" "--without-mssql" "--without-pdo-mssql" "--without-pi3web" "--with- 
pdo-oci-C *Wphp-sdktWoracletWinstantclientlOW'sdk, shared" "--with-oci8-C Wphp- 
sdkiřoracleWinstantclienti OW sdk, shared" "--with-oci8-11g-C:Wphp- 
sdkřoracletinstantclienti isdk shared” "--enable-object-out-dirz,,/obj/" "-- 
enable-com-dotnet-shared" "--with-mcryptzstatic" "--disable-static-analyze" "— 
with-pgo" 
Server API Apache 2,0 Handler 
Virtual Directory |enabled 
Support. 
Configuration C Windows 
File (php.ini) 
Path 
Loaded CWXAMPP*tphptifphp. ini 
Configuration 
File 
fnanal - 
J 
































图 1-47 测试 安装 成 功 显示 的 页 面 


0 PHP 文件 配置 


安装 PHP 后 还 可 以 根据 需要 编辑 php. in; 文件 对 PHP 的 配置 进行 设置 。 下 面 就 对 PHP 
配置 文件 php. ini 的 组 织 方 式 进行 简要 的 说 明 。 文 件 命 名 为 php. ini 的 原因 之 一 是 它 遵循 许多 
Windows 应 用 程序 中 INI 文件 的 常见 结构 。php. ini 是 一 个 ASCH 文本 文件 ， 并 且 被 分 成 几 个 
部 分 ， 每 一 部 分 包括 与 之 相关 的 各 种 变量 。 
每 一 部 分 类 似 于 如 下 结构 : 
[ MySection ] 
variable = " value" 


anothervariable = " anothervalue" 


各 部 分 的 名 称 通 过 方 括号 “[ ]” 括 起 来 放 在 顶部 ， 然 后 是 任意 数量 的 “变量 名 = 值 ” 
对 ， 每 一 对 占 单独 一 行 。 如 果 行 以 分 号 “;” 开 头 ， 则 表明 该 行 是 注释 语句 。 

在 php. ini 中 允许 或 禁止 PHP 功能 变 得 非常 简单 。 只 需要 将 相关 语句 注释 掉 而 无 需 删 
除 ， 该 语句 就 不 会 被 系统 解析 。 特 别 是 ， 当 希望 在 一 段 时 间 以 后 重新 打开 茶 种 功能 的 时 候 非 
常 方便 ， 因 为 不 需要 在 配置 文件 中 将 此 行 删除 。 

下 面 看 一 看 某 php. ini 文件 中 的 一 个 片段 : 


$9559555555555555555» 











;Language Options ; 


; Enable the PHP scripting language engine under Apache. 

engine = On 

; Enable compatibility mode with Zend Engine 1 ( PHP 4. x) 

zend. zel. compatibility mode = Off 

;Allow the < ? tag. Otherwise,only « ? php and < script > tags are recognized. 
; NOTE: Using short tags should be avoided when developing applications or 
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;libraries that are meant for redistribution , or deployment on PHP 
;servers which are not under your control , because short tags may not 
;be supported on the target server. For portable ,redistributable code, 
;be sure not to use short tags. 
short, open, tag = Off © 
; Allow ASP - style « 96 % > tags. 

asp_tags = Off 

;The number of significant digits displayed in floating point numbers. 

precision = 14 

在 这 个 文件 中 可 对 PHP 的 12 个 方面 进行 设置 包括: 语言 选项 、 安 全 模式 、 语 法 突出 

显示 、 森 项、 资源 限制 、 错 误 处 理 和 日 志 、 数 据 处 理 、 路 径 和 目录 、 文 件 上 传 、Fopen 包装 
器 、 动 态 扩 展 和 模块 设置 。php. ini 文件 存放 在 PHP 的 安装 路 径 ， 在 每 次 启动 PHP 时 都 会 读 
取 。 因 此 ， 在 通过 修改 php. ini 文件 改变 PHP 配置 之 后 ， 需 要 重启 Web 服务 器 以 使 配置 改变 
生效 。 本 书 的 实例 需要 配置 的 对 象 为 ; 





magic quotes gpc = On 


magic_quotes_gpc 功能 : 是 否 自动 为 GPC( get ,post,cookie) 传 来 的 数据 中 的 Vt NIE E JC 
RER o 

如 果 magic, quotes, gpc = On, 返回 1, PHP IRIRA AIIN post, get, cookie 过 来 的 数 
据 增 加 转 义 字符 “”， 以 确保 这 些 数据 不 会 引起 程序 ， 特 别 是 数据 库 语句 因为 特殊 字符 引起 
的 污染 而 出 现 致命 的 错误 。 

在 magic_quotes_gpc = On 的 情况 下 ， 如 果 输 入 的 数据 有 单 引号 (”)、 双 引号 (”) 、 反 
RR (V) 5 NUL (NULL 字符 ) 等 字符 都 会 被 加 上 反 和 斜 线 ， 这 些 转 义 是 必须 的 。 如 果 这 
个 选项 为 0 人 入， 返回 0， 那 么 就 必须 调用 addslashes 这 个 函数 来 为 字符 串 增加 转 义 。 


安装 MySQL 数据 库 


PHP 可 以 与 很 多 数据 库 完 美 结合 ， 从 而 开发 出 动态 网 站 。 对 于 初学 者 而 言 ，MySQL 数 
据 库 被 认为 是 最 容易 上 手 的。 本 节 就 介绍 MySQL 数据 库 的 下 载 与 安装 。 

















MySQL 数据 库 简 介 


MySQL 是 一 个 真正 的 多 用 户 、 多 线程 SQL 数据 库 服 务 器 。SQL (结构 化 查询 语言 ) 是 
世界 上 最 流行 的 、 标 准 化 的 数据 库 语言 。MySQL 是 一 个 客户 机 /服务 器 结构 实现 ， 由 一 个 服 
务 器 守护 程序 mysqld 和 很 多 客户 程序 以 和 库 组 成 。 

SQL 是 一 种 标准 化 的 语言 ， 它 使 得 存储 、 更 新 和 存 取信 息 更 容易 。 例 如 ， 能 用 SQL 语 
言 为 一 个 网 站 检索 产品 信息 及 存储 顾客 信息 ， 同 时 MySQL 也 允许 客户 足够 快 和 灵活 地 存储 
记录 文件 和 图 像 。 

在 这 里 推荐 使 用 MySQL 的 主要 原因 有 以 下 几 点 。 




















PHP*MySQL Dreamweaver 


1) 便宜 (通常 是 免费 ) 。 

2) 经 过 高 度 优化 ( HighlyOptimized ) 。 

3) 应 用 程序 通过 它 做 备份 比较 简单 。 

4) 为 不 同 的 数据 格式 提供 弹性 的 接口 。 

5) 较 好 学 且 操 作 简单 。 

MySQL 的 优点 有 以 下 几 点 。 

1. 避免 网 络 阻塞 

针对 多 个 使 用 者 共同 存 取 的 支持 ，MySQL 内 定 最 大 连接 数 为 100 个 使 用 者 。 但 是 ， 即 
使 网 络 上 有 大 量 数据 往来 ， 并 不 会 对 查询 优化 (query optimization). 有 多 大 的 影响 。 

2. 优化 

数据 库 结构 设计 也 会 影响 到 MySQL 的 执行 效率 ， 例 如 MySQL 并 不 支持 外 键 (Foreign 
key); 这 个 缺点 会 影响 到 数据 库 设 计 以 及 网 站 的 效率 。 

对 于 使 用 MySQL 做 数据 库 支 持 的 网 站 ， 应 该 将 重点 放 在 如 何 让 硬盘 存 取 减 少 到 最 低 、 
如 何 让 一 个 或 多 个 CPU 随时 保持 在 高 速 作 业 的 状态 ， 以 及 支持 适当 的 网 络 频 宽 ， 而 非 实 际 
上 的 数据 库 设 计 以 及 数据 查询 状况 。 

3. 多 线程 

MySQL 是 一 个 快速 、 多 线程 (multithread) 、 多 用 户 且 功 能 强大 的 关系 型 数据 库 管理 系 
统 (Relational database management system, RDBMS) , 。 也 就 是 说 当 客户 端 与 MySQL 数据 库 连 
接 时 ， 服 务 器 会 产生 一 个 线程 (thread) 或 一 个 进程 (process) 来 处 理 这 个 数据 库 连 接 的 请 求 
( request ) 。 

4. 可 延伸 性 以 及 数据 处 理 能 

MySQL 同时 具有 高 度 多 样 性 ， 能 够 提供 给 很 多 不 同 的 用 户 接口 ， 包 括 命令 行 、 客 户 端 
操作 、 网 页 浏览 絮 ， 以 及 各 式 各 样 的 程序 语言 接口 ， 例 如 C++、Perl、jJava、PHP 以 
及 Python。 

MySQL 可 用 于 UNIX, Windows, OS/2 等 平台 ， 也 就 是 说 它 可 以 用 在 个 人 计算 机 或 者 服 
aris Es 

5. 便于 学 习 

MySQL 支持 结构 化 查询 语言 (Structured Query Language, SQL) ， 那 么 精通 数据 库 的 人 
在 一 天 之 内 ， 就 可 以 学 会 MySQL， 对 于 初学 者 来 说 也 非常 容易 上 手 。 




















MySQL 数据 库 的 下 载 


可 以 到 MySQL 的 官方 网 站 http ;// www. mysql. com 下 载 MySQL 的 最 新 版 本 。 下 载 MySQL 
数据 库 的 步骤 如 下 : 

1) 打开 I 下 浏览 器 ,进入 MySQL 的 官方 网 站 主页 (http://www. mysql. com) 下 和 载 
MySQL 数据 库 ， 如 图 1-48 所 示 。 

2) 打开 主页 之 后 找到 相关 下 载 文件 ， 本 书 下 载 的 是 MySQL 的 版 本 mysql - 5. 6. 15 - 
win32. msi， 单 击 “Download (下 载 )” 按 钮 即 可 以 下 载 将 要 使 用 的 数据 库 ， 如 图 1-49 
所 示 。 





动态 网 站 开发 从 入 门 到 精通 
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Contact a MySQL Representative Search 







Login | Register 


MySQL 


MySQL.com 


The world's most popular open source database 





Downloads (GA) 


Products Services Partners Customers Why MySQL? News & Events How to Buy 





现在 立刻 尝试 


MySQL AH à : smmmm| New! MySQL Workbench 6.0 
-H Design, Develop, Administer, Migrate 
Windows, Linux, Mac OS X 


免费 网 络 研讨 会 
白皮书 


独立 软件 开发 商 和 原始 设备 制造 商 | 
Learn More » | 




















现在 购买 

联系 我 们 : 
OnDemand Web Seminars & 
* What's New in MySQL 5.7? 
* Automated Sharding and High Availability with MySQL Fabric | 
* Developing Windows Applications with MySQL: Part I, The Basics, Tools & Features 
* MySQL Replication: Discover What's New 
* More OnDemand Web Seminars - 
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图 1-48 打开 MySQL 主页 
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Please report any bugs or inconsistencies you observe to our Bugs Database. 
Contact Sales Thank you for your support! 

USA: +1-866-221-0634 
Canada: +1-866-221-0634 


Generally Available (GA) Releases Development Releases 
Germany: +49 89 143 01280 


France: +33 1 57 60 83 57 


Italy: +39 02 249 59 120 MySQL Installer 5.6.15 


UK: +44 207 553 8447 
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图 1-49 选择 下 载 的 版 本 











MySQL 数据 库 也 是 不 断 在 更 新 的 ， 对 于 读者 而 言 在 下 载 的 时 候 可 能 版 本 已 经 有 所 改变 ， 


这 并 不 影响 后 面 的 操作 和 使 用 ， 所 以 可 以 下 载 最 新 的 版 本 进行 安装 使 用 。 
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TSS MySQL 数据 库 的 安 


下 载 的 MySQL 数据 库 安装 包 有 240 MB， 有 具体 的 安装 步骤 如 下 : 
1) 双击 安装 程序 mysql - 5.6. 15 - win32. msi， 打 开 欢 迎 安装 对 话 框 ， 如 图 1-50 所 示 。 
该 版 本 较 早 期 的 一 些 版 本 的 安装 界面 有 很 大 改变 。 


ra 
[E] MySQL Installer em re 








Welcome My 


The MySQL Installer guides you through the installation and configuration of your 
MySQL products. Run it from the Start Menu to perform maintenance tasks later. 


Select one of the actions below: 


m Install MySQL Products 
S Guide you through the installation and configuration of your 
iion MySQL products. 


Gi y About MySQI 
l | Learn more about MySQL products and better understand how 
you can benefit the most. 


Resources 
Get more information on how to install MySQL and configure it 
to run efficiently on your machine. 


Copyright © 2013, Oracle and/or its affiliates, All nights reserved. Orade is a repeteret uium k of . 
Oracle Corporation and/or zs affiates, Other names may be trademarks of ter respective owners, ORACLE 

















1-50 开始 安装 


2) Hl "Install MySQL Products (安装 MySQL 产品 ) ”按钮 以 继续 安装 程序 ， 打 开 
Juega Agreement (终端 用 户 许可 )” 对 话 框 。 选 中 “I accept the license terms" 复 选 框 同 
合约 的 授权 ， 继 续 进行 安装 ， 如 图 1-51 所 示 。 

3) 单 击 [ we HXH, HJF “Find latest products (查找 最 新 版 的 产品 ) ”对 话 框 ， 提 示 
安装 之 前 可 以 连接 到 官方 网 站 进行 核查 并 下 载 更 新 版 的 软件 ， 这 里 选中 “Skip the check for 
updates (not recommended). ( 跳 过 更 新 )” 复 选 框 ， 如 图 1-52 所 示 。 

4) 单 击 [_ ex Jfk, FIF “Choosing a Setup Type. (选择 安装 类 型 )” 对 话 框 ， 选 择 
MySQL 的 安装 类 型 为 “Custom ( 自 定义 )”， 同 时 将 路 径 改 为 C:\MySQL， 如 图 1-53 d na 
5) 确认 后 ， 单 击 [_ we Ht, TIJT "Feature Selection. (安装 选择 ) ”对 话 框 ， 在 这 

建议 保持 安装 的 默认 值 ， 即 选中 所 有 的 安装 复 选 框 ， 如 图 1-54 所 示 。 

6) 单 击 [_nex HXH, HIF “Check Requirements (检查 组 件 )” 对 话 框 ,在 该 对 话 框 中 
要 求 安装 的 环境 中 必须 有 . NET Framework 4 和 Visual C ++ 等 开发 组 件 ， 如 图 1-55 所 示 。 

7) 如 果 计 算 机 中 没有 安装 相应 的 组 件 ， 单 击 _ eee 按钮， 则 安装 程序 就 会 自动 从 互联 
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License Agreement 


MySQL. Installer 
To install MySQL, you must accept the Oracle Software License Terms. 


GNU GENERAL PUBLIC LICENSE 
Version 2, June 1991 


License Information Copyright (C) 1989, 1991 Free Software Foundation, Inc., 
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA 
Everyone is permitted to copy and distribute verbatim copies 
iof this license document, but changing it is not allowed. 


Preamble 


The licenses for most software are designed to take away your freedom 
to share and change it. By contrast, the GNU General Public License is 
intended to guarantee your freedom to share and change free 
software--to make sure the software is free for all its users. This 

General Public License applies to most of the Free Software 

Foundation's software and to any other program whose authors commit to 
using it. (Some other Free Software Foundation software is covered by 
the GNU Library General Public License instead.) You can apply it to 

your programs, too. 


When we speak of free software, we are referring to freedom, not price. 
Our General Public Licenses are designed to make sure that you have 
the freedom to distribute copies of free software (and charge for this 
service if you wish), that you receive source code or can get it if you 
want it, that you can change the software or use pieces of it in new 

free programs; and that you know you can do these things. 

















|V| I accept the license terms 
































图 1-51 同意 安装 许可 





f [E] MySQL Installer 
TN Find latest products 
MySQL. Installer 


Before the installation is performed, the Installer will check if there are newer 
versions of the products you are about to install / already installed are available. 


Find latest products 
O Connect to the Internet 
O Fetch product update information 











Skip the check for updates (not recommended) 
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发 从 入 门 到 精通 








Choosing a Setup Type 


Please select the Setup Type that suits your use case. 


© Developer Default Aen Type Po m 
Allows you to select exactly which products you 
mice a rods needed for would like to install. This also allows to pick other 
y: evenpmen: purposes. server versions and architectures (depending on 
your OS). 





© Server only 


Installs only the MySQL Server 
product. 


© Client only 


Installs only the MySQL Client 
products, without a server. 








5 Full Installation Path: 


Installs all induded MySQL products C:WMysQL\ 
and features. 





图 Custom Data Path: 


Manually select the products that C: ProgramData MySQL MySQL Server 5.61 
should be installed on the system. 



































网 1-53 设 定安 装 类 型 和 目录 安装 








MySQL Installer 


LE 


MySQL. Installer 


Feature Selection 


Please select the products and features you would like to install on this machine. 


一 product Catalog: Architecture: 


D ee CNET Ek: v |64-Bit 


MySQL Server 5.6.15 MySQL Server 
The core MySQL database server 


Applications V| MySQL Server 
局 Client Programs 


MySQL Connectors W| Debug binaries 
|V| Development Components 





























Feature Selection 























¥| Client C API library (shared) 
B Documentation |V| Documentation 
V| Server data files 


















































Space available on driv 
Estimated Total Space required on driv 


























图 1-54 选择 安装 软件 














MySQL Installer 








pee 


m Installer 


Check Requirements 



















Check Requirements 


The following requirements must be installed before the selected products can be 
installed. If you don't want a particular requirement then go back and deselect the 
product that requires it. 





Requirement For Product 
(9) Microsoft Excel 2007 or greater MySQL For Excel 1.1.3 
(9j Microsoft .NET Framework 4 Client Profile MySQL Notifier 1.1.4 
(9 Microsoft Visual C++ 2010 32-bit runtime MySQL Workbench CE 6.0.8 
(9) Microsoft .NET Framework 4 Client Profile MySQL Workbench CE 6.0.8 
Q Visual Studio 2008, 2010, 2012 MySQL for Visual Studio 1.0.2 | 


Status 











Current Task 


The Product "MySQL for Visual Studio 1.0.2" requires "Visual Studio 2008, 2010, 2012" but it was 
not detected on this machine. "Visual Studio 2008, 2010, 2012" requires manual installation and 
must be installed prior to installing "MySQL for Visual Studio 1.0.2". By dicking 'Execute', "MySQL 
for Visual Studio 1.0.2" will be removed from the list of products to install. Once the "Visual 
Studio 2008, 2010, 2012" has been met, please run the MySQL Installer again and you will be 
able to complete installation. 














网 下 载 相 应 





的 组 件 安 装 程序 。 下 载 成 功 后 会 自动 弹出 相应 
“完成 ”按钮 ， 完 成 组 件 的 安装 ， 这 时 在 原来 “Check Requirements. (检查 组 件 )” 对 话 框 中 


图 1-55 提示 要 安装 的 组 件 


的 组 件 就 自动 勾 选 上 了 ， 如 图 1-56 所 示 。 





IEJ MysQL mule UA TU o o deis 
(H 2 2: 2 | 


- Installer 


Check Requirements 





Check Requirements 


The following requirements must be installed before the selected products can be 
installed. If you don't want a particular requirement then go back and deselect the 
product that requires it. 





Requirement For Product 
(9) Microsoft Excel 2007 or greater MySQL For Excel 1.1.3 
(9j Microsoft .NET Framework 4 Client Profile MySQL Notifier 1.1.4 
(9 Microsoft Visual C++ 2010 32-bit runtime MySQL Workbench CE 6.0.8 
(9) Microsoft .NET Framework 4 Client Profile MySQL Workbench CE 6.0.8 


Status 








Current Task 


All required prerequisites are met. Continue by dicking on the Next button. 





x Back Next > Cancel 





图 1-56 组 件 安装 完成 





组 件 的 开始 安装 对 话 框 ， 单 击 











8) 单 击 [ wer ESL, TIJf "Installation Progress (安装 进程 ) ”对话 框 ， 对 话 框 中 显示 


了 即将 安装 软件 的 进度 为 “To be Installed. (即将 被 安装 ) ”状态 ， 


如 图 1-57 所 示 。 
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AJ MySQL Installer h LEM 
|. c G 
| A Installation Progress 
MySQL. Installer 
p The following products will be installed or updated. 

J; Produt — | Status | Progress Notes 
[5] MySQL Server 5.6.15 To be installed 
[5] MySQL Workbench CE 6.0.8 To be installed 
[5] MySQL Notifier 1.1.4 To be installed 
[5] MySQL For Excel 1.1.3 To be installed 

[5] MySQL Utilities 1.3.5 To be installed | 
EJ Connector/ODBC 5.2.6 To be installed 
EJ Connector/C++ 1.1.3 To be installed 
Installation EJ Connector/J 5.1.27 To be installed 
EJ Connector/NET 6.7.4 To be installed 
E MySQL Connector/C 6.1 6.1.2 To be installed 
图 | MySQL Documentation 5.6.15 To be installed 
图 | Samples and Examples 5.6.15 To be installed 
Click [Execute] to install or update the following packages 
| < Back Execute Cancel 
= d 

















9) Ah eee | 按钮 ， 则 安装 程序 会 自动 开始 安装 所 有 的 程序 并 提示 安装 的 进程 ， 如 图 


1-58 所 示 。 


图 1-57 提示 即将 安装 
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5] MySQL Installer N Mem 
| n" 
. Installation Progress 
MySQL. Installer 
— niii The following products will be installed or updated. 
Product 0000 Status Progress — Notes 
Q [5] MySQL Server 5.6.15 Install success || 
2 [5] MySQL Workbench CE 6.0.8 Installing — | 

[5] MySQL Notifier 1.1.4 To be installed 
[5] MySQL For Excel 1.1.3 To be installed 

[5] MySQL Utilities 1.3.5 To be installed || 
EJ Connector/ODBC 5.2.6 To be installed 
EJ Connector/C++ 1.1.3 To be installed 
aerae EJ Connector/J 5.1.27 To be installed 
EJ Connector/NET 6.7.4 To be installed 
EJ MYSQL Connector/C 6.1 6.1.2 To be installed 
图 | MySQL Documentation 5.6.15 To be installed 
图 | Samples and Examples 5.6.15 To beinstalled 

Show Detais > 
C) 
— J 




















图 1-58 开始 安装 的 进程 
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10) 安装 完成 时 当 所 有 安装 选项 前 面 都 打上 对 勾 ， 则 表示 该 程序 安装 成 功 ， 安 装 完成 的 
对 话 框 如 图 1-59 所 示 。 


mp E Oi el 











Installation Progress 


MySQL. Installer 
The following products will be installed or updated. 











Product Status Progress Notes 
o MySQL Server 5.6.15 Install success 
[v] MySQL Workbench CE 6.0.8 Install success 
o MySQL Notifier 1.1.4 Install success 
o MySQL For Excel 1.1.3 Install error 
[v] MySQL Utilities 1.3.5 Install success 
[v] Connector/ODBC 5.2.6 Install success 
o Connector/C4-4 1.1.3 Install success 
nstol ion @ Connector/J 5.1.27 Install success 
o Connector/NET 6.7.4 Install success 
[v] MySQL Connector/C 6.1 6.1.2 Install success 
[7] MySQL Documentation 5.6.15 Install success 
[v] Samples and Examples 5.6.15 Install success 











Show Details > 














网 1-59 安装 完成 的 对 话 框 


11) 单 击 [ vex Pt, FIF “Configuration Overview (确认 预览 ) ”对 话 框 ， 提 示 安 装 
的 MySQL 数据 库 将 要 进行 确认 ， 如 图 1-60 所 示 。 
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— HE o 
二 MySQL Installer j 7l mE 
—— e. 
P Configuration Overview 
MySQL. Installer 
The following products will now be configured. 
Product Action to be performed Progress 
c» MySQL Server 5.6.15 Tnitial Configuration. | 
Configuration 
Show Details > 
( <Bak ][ wee ][ ewe 
L = = J 





图 1-60 “Configuration Overview (确认 预览 ) ”对 话 框 












QL*Dreamweaver 动态 网 站 开发 从 入 门 到 精通 
12) Áh nee PZH, FJI “MySQL Server Configuration (数据 库 确 认 ) ”对话 框 ， 提 
示 选 择 数 据 库 服务 器 的 安装 类 型 ， 这 里 选中 “Developer Machine. (开发 者 计算 机 )” 单 选 按 


钮 ， 其 中 “Enable TCP/IP Networking (设置 TCP/IP 工作 方式 的 选项 ) ”表示 将 MySQL 数据 
库 服务 器 注册 为 TCP/IP 的 服务 以 方便 管理 ， 同 时 端口 为 3306， 如 图 1-61 所 示 。 































P 
7] MySQL. Installer [mE 
. MySQL Server Configuration 1/3 
MySQL. Installer 
Server Configuration Type 
€ E Choose the corre uration type for this MySQL Server 
»i installation. This s jovs much system resources are assigned 
to the MySQL Ser 








Config Type: Development Machine 











避 Enable TCP/IP Networking 





-一 Enable this to allow TCP/IP 
through named pipes are al 


PortNumber: — 330 





king. Only localhost connections 
ven this option is skipped. 














网 Open Firewall port for network access 





Configuration 
Advanced Configuration 
» Select the checkbox below to get additional configurabon page where 
B VN you can set advanced options for this server instance. 
F] Show Advanced Options 

















Next > Cancel 











图 1-61 设 定安 装 类 型 和 目录 安装 


13) 选择 确认 模式 后 再 单 击 [C_ Nex PtH, FTIF “MySQL Server Configuration. (数据 库 确 
认 )” 对 话 框 的 第 二 步 ， 两 次 输入 前 面 安 装 时 设置 的 root 密码 (这 里 设置 的 密码 为 admin, 
后 面 章节 数据 库 登 录 全 是 使 用 admin), 具体 的 设置 如 图 1-62 所 示 。 


r 











“| MySQL Installer 














Em) 





] MySQL Server Configuration 2/3 
MySQL. Installer 


Root Account Password 


Enter the password for the root account. Please remember to store 
this password in a secure place. 


MySQL Root Password:  *eeee 
Repeat Password:  +eeee 


Password Strength: Weak 


MySQL User Accounts 


pr Create MySQL user accounts for your users and applications, 
, Assign a role to the user that consists of a set of privileges. 
Configuration 
2 iy 


MySQL Username Host User Role Add User 





























(Lose ][ Net> Cancel 














图 1-62 确认 安全 设置 
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14) REXA, Ahl we PH, FJI “MySQL Server Configuration (数据 库 确认 )” 
对 话 框 的 第 三 步 “Windows Service Details ( Windows 操作 系统 细节 设置 )”， 保 持 默认 值 ， 如 
图 1-63 所 示 。 
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[©] MySQL Installer "A (tm ) 











MySQL Server Configuration 3/3 


cb Installer 


Windows Service Details 


Please specify a Windows Service name to be used for this MySQL 
Puy Server instance. A unique name is required for each instance. | 


Windows Service Name: TE 








'J| Start the MySQL Server at System Startup 


m Run Windows Service as ... 
aI The MYSQL Server needs to run under a given user account, 


Based on the security requirements of your system you need to 
pick one of the options below. 








® Standard System Account 
Recommended for most scenarios. 


Configuration 
(^j Custom User 


An existing user account can be selected for advanced scenarios. 





























图 1-63 Windows 操作 系统 细节 设置 面板 























15) 单 击 [ nt PtH, HIF “Configuration Overview (确认 预览 ) ”对 话 框 ， 如 果 前 面 
的 设置 和 安装 全 部 正确 ， 则 安装 的 选项 前 面 将 会 显示 对 勾 ， 如 图 1-64 所 示 。 


r 








[©] MySQL Installer LN rem) 








Configuration Overview 


The following products will now be configured. 





Product Action to be performed Progress 


Configuration 











Show Details > 
| <Back Next » Cancel 


























Kd 1-64 确认 预览 面板 








16) 确认 后 再 单 击 [_ ne PRH, HARA ÉI “Installation Complete (完成 安装 ) ”对 话 
框 ， 单 击 选 择 “Star MySQL Workbench after Setup (完成 安装 后 启动 MySQL. 的 工作 界面 )” 
复 选 框 ， 如 图 1-65 所 示 。 


f [E] MySQL Installer 











p Installation Complete 
MySQL. Installer 


The installation procedure has been completed. 


Copy Log to Clipboard 








V] Start MySQL Workbench after Setup 








Complete 























K1-65 完成 安装 的 对 话 框 


f HREH, MySQL 数据 库 的 安装 就 完成 了 。 用 上 述 的 方法 安装 完 
数据 库 后 打开 C: A FHI MySQL/MySQL Server5. 6/data 文件 夹 ， 如 图 1-66 所 示 。 


























O- L o» 计算 机 » Acer (C) » MySQL » MySQL Server 5.6 » data » al HE data p 
组 织 " 包含 到 库 中 v 共享 刻录 新 建文 件 夫 := mn e 
TEE n i 修改 日 期 类 型 大 小 

E 下 载 |: mysql 2014/1/1 10:01 bu 

m 2m |» performance schema 2014/1/1 10:01 文件 去 

3 晤 后 访问 的 位 置 L ib logfileo 2013/11/17 19:56 ”文件 49,152 KB 

Liib.logfilez 2013/11/17 19:566 ”文件 49,152 KB 

: Li ibdatal 2013/11/17 19:556 ”文件 12,288 KB 
v 库 

Buen - 

图 图 片 

国 文档 

"EC 
I 计算 机 

色 Acer (C:) 

ca Heke (D) —— 

ca 本 地 磁盘 (E:) 

| 5 个 对 象 

A 




















图 1-66 数据 库 的 存放 位 置 
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该 文件 夹 是 数据 库存 放 的 默认 的 位 置 ， 即 后 面 章节 所 有 实例 的 数据 库 就 可 以 直接 放 在 
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. 管理 MySQL 数据 库 


在 安装 完 MySQL 数据 库 后 ， 可 以 自动 运行 数据 库 的 管理 软件 MySQL. Workbench, 4H 
图 1-67 所 示 。 该 数据 库 管理 软件 是 英文 版 的 ， 对 于 英语 不 是 很 精通 的 学 习 者 在 使 用 上 有 一 
定 的 难度 。 在 国内 比较 普及 的 针对 MySQL 数据 库 进 行 管理 的 还 有 好 几 款 软件 ， 其 中 phpMy- 
Admin 是 最 简单 的 网 页 版 ， 由 于 本 软件 有 中 文 版 ， 配 置 也 非常 简单 ， 这 里 推荐 使 用 phpMy- 
Admin 对 MySQL 数据 库 进 行 管理 应 用 ， 如 图 1-67 所 示 。 
MySQL Workbench le 
À 


File Edit View Database Tools Scripting Help 





























MySQL Connections ®© © a Shortcuts 


Local instance MySQL56 TN MySQL Doc Library 
—— 
$ root 8 na 
localhost3306 
Z MysQL Utilities 


v» 


Database Migration 


MySQL Bug Reporter 


Ve EORORO) 


B sakila full 


Workbench Blogs 


IS Planet MySQL 


Workbench Forums 

















图 1-67 MySQL Workbench 主 界面 

















| 1. 6.1 | phpMyAdmin 的 下 载 J 

phpMyAdmin 就 是 一 种 MySQL 的 管理 工具 ， 安 装 该 工具 后 ， 即 可 以 通过 Web 形式 直接 
管理 MySQL 数据 库 ， 不 需要 通过 执行 系统 命令 来 管理 ， 非 常 适 合 对 数据 库 操作 命令 不 熟悉 
的 数据 库 管 理 者 。 下 面 就 从 phpMyAdmin 官网 上 下 载 该 软件 。 

下 载 的 步骤 如 下 : 

1) 打开 phpMyAdmin 的 官方 站 点 http://www. phpmyadmin. net/ ， 在 页 面 中 单 击 “ Down- 
load (下 载 ) ”进入 下 载 频道 ， 如 图 1-68 所 示 。 

2) 选择 最 新 的 版 本 单 击 “Download 4. 1.3” 文 件 包 进行 下 载 ， 如 图 1-69 所 示 。 

3) 下 载 后 的 ZIP 文件 通过 解压 软件 解压 到 本 地 硬盘 。 如 果 本 地 有 MySQL 则 可 在 本 地 测 




























































































Hh phpMyAdmin - Downlo. x 





Q fi D www.phpmyadmin.net/downloads/ 


Home | Hews Security | Support | Docs Try | Contribute Sponsors Download 


Bringing MySQL to the web 
phpMyAdmin 


Download 


Many operating systems already include a phpllyAdmin package and will automatically keep it updated, however 
these versions are sometimes slightly outdated and therefore may be missing the latest features. Additionally, 
the configuration process varies widely by package and may not adhere to the official phpMyAdmin 
documentation. That being said, it is usually the quickest way to an updated installation. Please contact your 
OS vendor for more information. Some additional information is also available in our documentation. If you 
just want to try phplyAdmin in a virtual machine, you might want to check the available software appliances 
which provide phpMyAdmin. 











If you do not find a suitable package or wish to install your own phpllyAdmin, you can download one of the 
following kits. Please note that each version has requirements for the minimum PHP and MySQL versions. 


Since July 2015 all phpMyAdmin releases are cryptographically signed by the releasing developer. You should 


verify that the signature matches the archive you have downloaded. Verification instructions are placed in our 
documentation in the Verifying phpllyhdmin releases chapter. 


phpMyAdmin 4. 5. 1 














图 1-68 FÆ phpMyAdmin 频道 





















http://sourceforge.net/projects/phpmyadmin/postdownload?source-dlp proxl ris 
Find out more about ph... X 











JdVd IIIIVIL ECUNU 
www.inetsoftware.de/jwebengine 


WYSIWYG HTML Editor embedded in 
your App. Its made of pure Java. 


arem 


m 

















Click Run or Open Follow our Easy Enjoy your new software 
to begin Installation Wizard | 
SourceForge| ”您 是 要 打开 还 是 保存 来 襄 10.67.126.71 的 phpMyAdmin-4.1.3-all-languages.zip (7.98 MB)? x | 
一 一 打开 (O) BERG T | Bu | — E 























图 1-69 选择 下 载 的 文件 包 


试 ， 这 里 将 所 有 解压 文件 复制 到 C:\Apache\Apache2 \htdocs 文件 夹 内 ， 如 图 1-70 所 示 。 则 
可 通过 Apache 服务 器 访问 phpmyadmin 这 个 数据 库 管理 软件 ， 访 问 的 方法 是 在 浏览 需 中 输入 
访问 地 址 “http ://localhost/phpmyadmin” o 




















QUO" Lo» 计算 机 » Acer(C) » Apache » Apache2 » htdocs ， ball 388 htdocs p 














组 织 FIF 包含 到 库 中 ” 共享 刻录 FER E- m @ 














FEPER A £m f 修改 日 其 类 型 大 小 





b TE | 上 上 phpMyAdmim 2013/12/31 5:50 ”文件 夫 | 
m sm SB phpMyAdmin-4.L3-allanguages.zip 2014/1/1 10:37 WinRAR ZIP 压缩 .. 8,176 KB 














phpMyAdmim 修改 日 期: 2013/12/31 5:50 
j| xem 





























图 1-70 解压 缩 到 Apache 站 点 文件 内 








|^ | phpMyAdmin 的 安装 


无 论 是 在 本 地 测试 还 是 在 远程 服务 器 上 测试 ， 都 需要 进行 如 下 的 文件 配置 才能 正常 使 用 
phpMyAdmin 。 

配置 的 方法 也 比较 简单 ， 具 体 的 配置 步 又 如 下 : 

1) 在 下 载 解压 下 来 的 文件 中 找到 文件 config. sample. inc. php， 这 是 phpMyAdmin 配置 文 
件 的 样本 文件 ， 需 要 把 该 文件 中 的 所 有 代码 复制 ， 然 后 新 建 一 个 文件 config. inc. php, HA 
代码 粘贴 。 文 件 config. inc. php 是 phpMyAdmin 的 配置 文件 ， 上 传 服务 器 时 必须 上 传 该 文件 ， 
如 图 1-71 所 示 。 

2) 对 于 config. inc. php 文件 ， 最 重要 的 就 是 修改 加 入 phpMy Admin 连接 MySQL 的 用 户 名 
和 密码 ， 寻 找到 代码 行 。 

PHP 代码 


// $cfgl Servers J[ $i][ 

// $cfgl Servers ][ $i][ controlpass ] = pmapass ; 
// $cfgl Servers ][ $i][ controluse? ] = pma ; 

// $cfgl Servers ][ $i][ 


将 “//” 删 除 ， 同 时 输入 MySQL 中 配置 的 用 户 名 和 密码 ， 比 如 这 里 : 
PHP 代码 


1 1 ) 
controluse! ] = pma ; 


1 ' 1 
controlpass ] = pmapass ; 


$cfg[l Servers ][ $i][ controluset ] 2 root ; 
$cfgl Servers ][ $i][ controlpass ] = admin ; 
$cfgl Servers ][ $i][ controluset ] 2 root ; 


$cfgl Servers ][ $i][ controlpass ] = sss*** ; 


修改 后 的 文档 如 图 1-72 所 示 。 


415 CA 









d 



























































O- | « Acer(C) » Apache » Apache2 » htdocs » phpMyAdmim » - | 好 | | F phpMyAdmim P 
组 织 DAF AR 新 建文 伯 夫 |" d e 
raum 请 名称 修改 日 期 类 型 大 小 

TE L] Changelog 2013/12/31 5:50 文件 24 KB D" 
m ss L changelog.php 2013/12/31 5:50 PHP 文件 5 KB S 
E E Li Sk re. php 2013/12/31 5:50 PHP 文件 1KB E 
L.] composer.json 2013/12/31 5:50 JSON 文件 1KB 
| | config.sample.inc.php 2013/12/31 5:50 PHP 文件 5 KB 
E L] CONTRIBUTING.md 2013/12/31 5:50 MD 文件 1KB 
Bus z| [db_create.php 2013/12/31 5:50 PHP 文件 5 KB 
图 图 片 口 db. datadict.php 2013/12/31 5:50 — PHP 文件 9 KB 
国 文档 |] db events.php 2013/12/31 5:50 PHP 文件 1KB 
AER |] db_export.php 2013/12/31 5:50 — PHP 文件 3 KB 
L] db import.php 2013/12/31 5:50 — PHP 文件 1KB 
而 计算 机 | db operations.php 2013/12/31 5:50 PHP 文件 10 KB 
li Acer (C) L db. printview.php 2013/12/31 5:50 — PHP 文件 6 KB 
db qbe.ph| 2013/12/31 5:50 PHP X: 2 KB 
exu D) D H dbabephp di 32 
L] db. routines.php 2013/12/31 5:50 — PHP 文件 1KB 
ca 本 地 磁盘 (E) E 
L] db search.php 2013/12/31 5:50 PHP 文件 2KB 
2s dh eal ehe 2012412431 5:50. DHD Frit 1KR M 
config.sampleinc.php I$z:E8&: 2013/12/31 5:50 创建 日 期 : 2014/1/1 10:38 
PHP 文件 大 小 : 4.13 KB 
图 1-71 创建 config. inc. php 文件 
站 config.inc.php - 记事 本 elak) 





ZPA 编辑 (E) f&xt(O) EEV) “帮助 (H) 





<?php/* vim: set expandtab sw-4 ts-4 sts=4: *//** * phplyAdmin sample configuration, you can use it 

as base for * manual configuration. For easier setup you can use setup/ * * All directives are 

explained in documentation in the doc/ folder * or at «http://docs. phpmyadmin. net/>. * * @package 

PhpMyAdmin *//* * This is needed for cookie based authentication to encrypt password in * cookie */ 

$cfg[' blowfish secret'] = 'a8bTc6d'; /* YOU MUST FILL IN THIS FOR COOKIE AUTH! *//* * Servers 

configuration */$i = 0;/* * First server */$i++;/* Authentication type */$cfeU Servers’ ] [$i] 

* auth | type SE * cookie fh Server, parameters */$cfsl Servers’ ] [$i][ host" ] = ° localhost’ ;$cfg 

l Servers’ ] [$i] [l connect, type' ] = ° tep’ ;$cfgU Servers’ J[$i] l compress ] = = false;/* Select mysql if 

your server does not have mysqli */$cfel Servers’ ] [$i][’ extension ] = ?mysql 让 ;$cfgl Servers’ ] [$i] 
' AllowNoPassword ] = false; /* * phpllyAdmin, configuration storage settings. *//* User used_to 

manipulate with stor */// $cfg[ Servers’ ] [$i] [ controlh t '!] 2t p Servers’ ][$i] 

d $cfg [ Servers ][$1][ controluser ] = ° root :// EA Servers. J1$i] 

IEE, /+ Storage database and tables */// ScfgL Servers J[$i] l pmadb: I 

" phpmyadmin ;// $cfzL Servers ] [$i][ bookmarktable'] = "pma  bookmark'; HA $cfzl Servers’ ] [$i] 

"relation ] = 'pma relation ;// $cfg[ Servers’ ] [$i][’ table info' ] = 'pma table info ;// $cfz 

* Servers’ ] [$i][ table coords'] = "pma, table coords, I jcfg[ Servers ] [$i]C pdf pages ] = 

"pma pdf pages ;/f ScfgU Servers’ 1[811U colum info. = 'pma column: info ; ff $cfgľ Servers’ ] [$i] 

[ history ] =° pma ] history ; T4 $cfgU Servers’ J[$i] l table_uiprefs’ ] = "pma table uiprefs' ;// $cfg 
l Servers’ J[$i] l tracking’ ]-2'pma : tracking ; :VA ScfgU Servers: 13i] [ designer, coords ] = 

^pma . designer . coords' md $cfg[ Servers’ J [$2 userconfig’ ] = 'pma userconfig ff ScfgU Servers’ ] 

$i][ recent’ ] = pma ; recent ;// $cfgl Servers ] [$i] users ] = 'pma users z $cfg[ Servers’ ] 

[$i] l usergroups’ ] = 'pma usergroups ;// $cfg[’ Servers’ ][$i] l navigationhiding Ts 

'pma navigationhiding ;/* Contrib / Swekey authentication */// $cfg[ Servers’ ] [$1] 

' auth swekey config ] = ' /etc/swekey-pma. conf ;/* * End of servers configuration *//* * Directories 

for saving/loading files from server */$cfg[ UploadDir' ] = '';$cfg[ SaveDir ] = '' ;/** * Defines 

whether a user should be displayed a "show all (records)" * button in browse mode or not. * default 

= false *///$cfz[ ShowAll'] = true;/** * Number of rows displayed when browsing a result set. If the 

result * set contains more rows, "Previous" and “Next”. * default = 30 *///$cfz[' MaxRows’ ] = 50; /** 

* disallow editing of binary fields * valid values are: * false allow editing *  'blob' 

allow editing except for BLOB fields * “noblob disallow editing except for BLOB fields *  'all' 



























^ 

















1-72. 修改 后 的 文档 


$cfgl blowfish secret ] 2' ; 
// 设 置 内 容 为 Cookie 


修改 为 : 


$cfg[ blowfish secre! ] = evernory 


3) 如 果 需 要 通过 远程 服务 器 调试 使 用 phpMyAdmin， 则 需要 添加 blowfish. __ 
定义 Cookie ， 寻 找到 代码 行 。 
PHP 代码 


Secret 内 容 
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设置 后 如 图 1-73 所 示 。 
( 71 confoincphp -记事 本 "Ah CA eek) 


XHA RRE EO SEV EAH 


<?php/* vim: set expandtab sw-4 ts=4 sts=4: *//** * phpMyAdmin sample configuration, you can use it ^ 
as base for * manual configuration. For easier setup you can use setup/ * * All directives are 
explained in documentation in the doc/ folder * or at «http://docs. phpmyadmin. net/>. * * (package 
PhpMyAdmin *//* * This is needed for cookie based authentication to encrypt password in * cookie */ 
Ea EN /+ YOU MUST FILL IN THIS FOR COOKIE AUTH! *//* * Servers 
configuration */$i = 0;/* * First server */jitt;/* Authentication type */$cfgU Servers’ ] [$i] 

[ auth Ltype ] =” cookie f Server, mee */$cfg[ Servers’ ] [$i][C host! ] = 'localhost' ;$cfg 

l Servers’ ] [$i][ connect type ] = ;$cfgľ Servers’ J[$i] l compress ] = = false; f* Select mysql if 
your server does not have mysqli sets Servers’ ][$1][ extension ] = ' mysqli’ ;$efgl Servers’ ] [$i] 
['AllowNoPassword ] = false; /* * phpltyAdmin configuration storage Ld *//* User used to 
manipulate with storage */// $cfz[ Servers? JEsi E controlhost? gia / $cfgl Servers’ ] [$i] 

[ controlport' ] = °° ;// $cfg l Servers’ ] [$i] l’ controluser ] = ’ root? E Do, Servers ji 

l controlpass'] = ° admin ;/* Storage database and tables */// $cfg[' Servers’ ] [$i][ pmadb’ ]- 

* phpmyadmin? M $cfzU Servers’ J][$i] [l bookmarktable'] = 'pma bookmark j“ $cfgU Servers’ ] [$i] 

[ relation’ ] = 'pma relation ;// Jeer Servers’ JEsi] E table info ] = 'pma table info :// $cfg 

LU Servers Iisi table coords' j= | table coords ;// jcfg[ Servers eis pdf pages ] = 

"pma pdf pages :AAA $cfe[ Servers JI:]T column info j= pma column .: info' ;/ f $cfgU Servers’ ] [$i] 
D history. l2'pma ] history ; Wf $cfg[’ Servers’ ][$i]l table. Luiprefs' lz2'pma table _uiprefs’ ; ;// $cfg 























l Servers’ ][$1]U tracking’ ] = ° pma, | tracking ; T $cfgU Servers. ] [9 designer, coords’ ] = 
pma | designer_ coords' Jm efel Servers’ ] [$i ' userconfig - 'pma 1 userconfig'; A $cfgU Servers’ ] 
[$i][ recent ] = "pma; recent ;// $cfgU Servers’ ] [$i * users ] 2"pma users ;// $cfg[ Servers 一 


[$i]C usergroups ] = pma j usergroups ;// $cfg[ Servers’ ] [$i] P navigationhi ding ]z 

pma 1 navigationhiding ; T Contrib / Swekey authentication */// $cfg[ Servers’ ] [$i] 

[ auth, swekey. config ] = ’ /etc/swekey-pma. conf ;/* * End of servers configuration *//* * Directories 
for saving/loading files from server */$cfg[ UploadDir'] = "5 ;$cfgľ SaveDir ] =°? ; /** * Defines 
whether a user should be displayed a "show all (records) " * button in browse mode or not. * default 
= false *///$cfg[ ShowAll'] = true; /e* * Number of TOWS displayed when browsing a result set. If the 
result * set contains more rows, "Previous" and Next”. * default = 30 *///$cfzU MaxRows’ 1s = p fk 
* disallow editing of binary fields * valid values are: * false allow editing * 

allow editing except for BLOB fields *  'noblob' disallow editing except for BLOB no. ai 'alr 


























图 1-73 设置 Cookie 权限 

















在 还 浏览 器 中 输入 http://127. 0. 0. 1/phpmyadmin/， 即 可 以 进入 软件 的 管理 界面 ， 选 
择 相关 数据 库 可 看 到 数据 库 中 的 各 表 ， 可 以 进行 表 、 字 段 的 增删 改 ， 还 可 以 导入 、 导 出 数据 


库 信息 ， 如 图 1-74 所 示 。 



























































: 3 Hh CH EI 
[€ ] 起 httpi//127.001/phpmyadmin/sPMAURL-Oindex php?db- &table-&server- 1&target-&token-6dd601c56716ee3d793cd 19c268b2c7a. P-ex| i ve i9: 
i, 127001 / 127.0.0.1 | ph... x [xu] E ES 
务 器 
phpMyAdmin ARAS: 127.0.0.1 
2B ONG 回 ARF Æ SQL & 状态 s; H^ B S BSA 咏 设 置 l SU p) 变 里 v 更 多 
ea —| 
| (最 近 使 用 的 表 ) -. 了 | - 
— — —— | 常规 设置 数据 库 服务 器 
国 - 梧 cdcol TENES = 3 
Sa information_schema = 服务 器 连接 排序 规则 GO :[ utf8 general ci 了 | ”服务 器 : 127.0.0.1 via TCP/IP 


* 服务 器 类 型 : MySQL 


eeu 服务 器 版 本 : 5.6.14 - MySQL C: i 
* SEX -My ommunity 
H performance schema Server (GPL) 


zx 
ŒH phpmyadmin " S 
2 s eu 外 观 设置 ”协议 版 本 : 10 
i * 用户: root@localhost 


ŒH 3 webauth ————— pd ; 
im & 语言 - Language 图 :| HX - Chinese simplified 图 | ”服务 器 字符 集 : UTF-8 Unicode (utf8) 
































s 主题 : | pmahomme z| 


C Ic 网 站 服务 器 


P 更 多 设置 - Apache/2.4.7 (Win32) OpenSSU10 1e 
PHP/5.5.6 

* 数据 库 客户 端 版 本 : ibmysql - mysqind 5.0.11- 
dev - 20120503 - $Id: 
40933630edef551dfaca7 1298a83fad8d03d62dà 
s 





























* PHP 扩展 : mysqli @ | 


HAE 409, RREME: 413 -| 



































图 1-74 软件 的 管理 界面 
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| 解决 PHP 与 MySQL 乱码 问题 


在 初次 配置 PHP 运行 支持 MySQL 后 ， 对 于 初学 者 来 说 ， 中 文 乱码 是 开始 学 习 时 遇 到 的 
第 一 个 问题 。 本 节 将 重点 介绍 如 何 解决 这 个 问题 。 

一 般 说 来 ， 乱 码 的 出 现 有 两 种 原因 。 首 先是 由 于 编码 (Charset) 设置 错误 ， 导 致 浏览 
器 以 错误 的 编码 来 解析 ， 从 而 出 现 了 满 屏 乱七八糟 的 符号 ， 不 能 正常 显示 中 文 ; 其 次 是 文件 
被 以 错误 的 编码 打开 ， 然 后 保存 ， 比 如 一 个 文本 文件 原先 是 GB2312 编码 的 ， 却 以 UTF-8 
编码 打开 再 保存 。 

要 解决 上 述 乱 码 问题 ， 首 先 需 要 知道 开发 中 哪些 环节 涉及 编码 。 

1) 文件 编码 被 修改 。 先 要 明确 页 面 文件 (. html, . php 等 ) 本 身 是 以 何 种 编码 来 保存 
的 。 记 事 本 和 Dreamweaver 在 打开 页 面 的 时 候 会 自动 识别 文件 编码 ， 因 而 不 太 会 出 问题 。 而 
ZendStudio 却 不 会 自动 识别 编码 ， 它 只 会 根据 首选 项 的 配置 ， 固 定 以 某 种 编码 打开 文件 ， 如 
果 用 错误 编码 打开 文件 ， 当 做 了 修改 之 后 保存 时 ， 乱 码 就 出 现 了 。 

2) 页 面 声明 编码 不 统一 。 在 HTML 代码 HEAD 里 面 ， 可 以 用 < meta http - equiv = 
" Content - Type" content = " text/html" ; charset = " XXX" /> 来 告诉 浏览 兢 网 页 采用 了 什么 编 
码 。 目 前 中 文 网 站 开发 中 XXX 主要 用 的 是 GB2312 和 UTF-8 两 种 编码 。 

3) 数据 库 连 接 编码 不 正确 。 进 行 数据 库 操 作 的 时 候 ， 要 明确 以 哪 种 编码 与 数据 库 传输 
数据 ， 这 里 需要 注意 的 是 不 要 与 数据 库 本 身 的 编码 混淆 ， 比 如 MySQL 内 部 默认 是 latinl 编 
码 ， 也 就 是 说 MySQL 是 以 latinl 编码 来 存储 数据 ， 以 其 他 编码 传输 给 MySQL 的 数据 会 被 转 
换 成 latinl 编码 。 

知道 了 网 站 开发 中 哪些 地 方 涉及 了 编码 ， 也 就 知道 了 产生 乱码 的 原因 。 下 面 是 一 些 常见 
的 错误 情况 与 解决 方法 。 

问题 一 : 数据 库 采 用 UTFS 编码 ， 而 页 面 声明 编码 是 GB2312。 

这 是 最 常见 的 产生 乱码 的 原因 。 这 时 候 在 PHP 脚本 里 面 直接 SELECT 数据 得 到 的 就 是 
乱码 ， 需 要 在 查询 前 先 使 用 mysql_query(" SET NAMES GBK" ) 来 设置 MySQL 连接 编码 ， 保 
证 页 面 声明 编码 与 这 里 设 定 的 连接 编码 一 致 (GBK 是 GB2312 的 扩展 ) 。 

如 果 页 面 是 UTF-8 编码 的 话 ， 可 以 用 mysql_query("SET NAMES UTF8" ) ， 注 意 拼写 是 
“UTF8” 而 不 是 “UTF-8”。 假 如 页 面 声 明 的 编码 与 数据 库 内 部 编码 一 致 则 可 以 不 设 定 连 接 



































编码 。 
例如 ， 本 书 的 购物 车 系统 的 数据 库 连接 时 设置 的 编码 规则 如 下 。 
<? php 
$conn = mysql. connect( " localhost" ," root" ," admin" ) or die(" 数 据 库 服 务 器 连接 错误 ". mysql. 
error( ) ) ; 


mysql. select, db( " db, shop" , $conn) or die(" 数 据 库 访问 错误 ". mysql. error( ) ) ; 
mysql. query ( " set character set gb2312" ) ; 
mysql, query( " set names gb2312" ) ; 
7» 


MySQL 的 数据 输入 /输出 比 上 面 讲 得 更 复杂 ，MySQL 配置 文件 my. ini 中 定义 了 两 个 默认 
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编码 ， 分 别 用 [ client] 里 的 default- character- set 和 [ mysqld ] 里 的 default- character- set 来 设 定 
默认 时 候 客 户 端 连接 和 数据 库 内 部 所 采用 的 编码 。 上 面 指定 的 编码 其 实 是 MySQL 客户 端 连 
接 服 务 器 时 候 的 命令 行 参 数 character_set_client， 来 告诉 MySQL 服务 器 接收 到 的 客户 端 数 据 l 
是 什么 编码 的 ， 而 不 是 采用 默认 编码 。 > 

问题 二 : 页 面 声明 编码 与 文件 本 里 编码 不 一 致 。 

这 种 情况 很 少 发 生 ， 因 为 如 果 编 码 不 一 至 ,美工 做 页 面 的 时 候 在 浏览 絮 看 到 的 就 是 乱 
码 。 更 多 时 候 是 发 布 以 后 修改 一 些小 BUG， 由 于 以 错误 编码 打开 页 面 然后 保存 导致 的 乱码 ; 
或 者 是 用 某 些 FTP 软件 直接 在 线 修改 文件 ， 比 如 CuteFTP， 由 于 软件 编码 配置 错误 而 导致 转 
换 错 了 编码 。 

问题 三 ， 服务 器 Apache 设 定 了 服务 融 全 局 的 默认 编码 。 

一 些 租用 虚拟 主机 的 读者 ， 明 明 上 述 3 项 编码 都 设置 正确 ， 但 还 是 有 乱码 。 比 如 ， 网 页 
是 GB2312 编码 的 ，IE 等 浏览 絮 打 开 却 总 是 识别 成 UIF-8， 网 页 HEAD 里 面 已 经 声明 是 
GB2312 了 ， 手 动 修改 浏览 器 编码 为 GB2312 后 页 面 显示 正常 。 产 生 原 因 是 服务 器 Apache ix 
定 了 服务 器 全 局 的 默认 编码 ， 在 httpd. conf 里 面 加 了 AddDefaultCharset UTF-8。 这 时 候 服 务 
器 会 首先 发 送 HTTP 给 浏览 器 ， 其 优先 级 比 页 面 里 声明 编码 高 ， 自 然 浏览 器 就 发 生 识 别 错 
误 。 解 决 办 法 有 两 个 ， 是 管理 员 在 配置 文件 自己 的 虚 机 里 加 上 一 条 AddDefaultCharset 
GB2312 来 覆盖 全 局 配置 ， 二 是 在 自己 目录 的 . htaccess 里 进行 相应 配置 。 












































ES 2 ea PHP 编程 基础 


PHP 是 一 种 易于 使 用 的 服务 器 端 脚本 语言 ， 只 需要 很 少 的 编程 知识 就 能 使 用 PHP 建立 
一 个 真正 具有 交互 功能 的 Web 站 点 。 对 于 初学 者 而 言 ， 需 要 花 一 些 工 夫 掌 握 PHP 的 编程 基 
础 。 本 书 以 最 简单 易学 的 方法 介绍 一 些 PHP 包括 变量 、 常 量 、 运 算 符 、 控 制 
语句 以 及 数组 等 ， 通 过 学 习 这 些 基础 知识 ,读者 能 更 深入 地 了 解 PHP. 
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主要 掌握 以 下 知识 点 


在 Dreamweaver 中 进行 PHP 开发 平台 的 搭建 
PHP 程序 编写 的 基础 知识 

掌握 PHP 表单 变量 的 使 用 

PHP 程序 中 常量 、 变 量 、 表 达 式 以 及 函数 的 基础 
重点 掌握 PHP 和 MySQL 数据 库 的 操作 





PHP 编 程 基础 





在 Dreamweaver 中 建立 PHP 执行 环境 
Dreamweaver CC 这 套 软件 提供 了 网 站 开发 的 整合 性 环境 ， 它 可 以 支持 不 同 服务 器 技术 ， 


如 ASP、PHP、JSP 等 ， 建立 动态 支持 数据 库 的 网 络 应 用 程序 ， 同 时 也 能 让 不 懂 程 序 代码 的 
网 站 设计 人 员 或 初学 者 ， 在 不 用 编写 程序 代码 的 情况 下 ， 学 习 动 态 网 页 技术 的 设计 。 
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7L Dreamweaver 进行 网 站 建设 的 步骤 





在 开始 制作 网 站 之 前 ， 还 要 了 解 在 Dreamweaver CC 中 的 网 页 设计 和 发 布 流程 。 它 可 以 
分 为 如 下 5 个 主要 步骤 。 

第 一 步 : 规划 网 站 站 点 

需要 了 解 网 站 建设 的 目的 ， 确 定 网 站 提供 的 服务 以 及 针对 的 是 什么 样 的 访问 者 ， 以 确定 
网 页 中 应 该 出 现 什 么 内 容 。 

第 二 步 : 建立 站 点 的 基本 结构 

Dreamweaver CC 可 以 在 本 地 计算 机 上 建立 整个 站 点 的 框架 ， 并 在 各 个 文件 夹 中 合理 地 安 
置 文档 。Dreamweaver CC 可 以 在 站 点 窗口 中 以 两 种 方式 显示 站 点 结构 ， 一 种 是 目录 结构 ， 另 
一 种 是 站 点 地 图 。 可 以 使 用 站 点 地 图 方式 快速 构建 和 查看 站 点 原型 。 一 旦 创建 了 本 地 站 点 并 
生成 了 相应 的 站 点 结构 ， 创 建 了 即将 进一步 编辑 的 各 种 文档 ， 就 可 以 在 其 中 组 织 文档 和 
数据 。 

第 三 步 : 实现 所 有 页 面 的 设计 

建立 站 点 之 后 ， 进 入 Dreamweaver CC 软件 ， 开 始 进 行 页 面 的 版 面 规划 设计 ， 利 用 强大 
的 编辑 设计 功能 实现 各 种 复杂 的 表格 ， 然 后 组 织 页 面 内 容 。 为 了 保持 页 面 风 格 统一 可 以 利用 
模板 来 快速 生成 文档 。 

第 四 步 : 充实 网 页 内 容 

在 创建 了 基本 版 面 页 面 后 ， 就 要 往 框架 里 填充 内 容 。 在 文档 窗口 中 合适 的 地 方 ， 可 以 输 
入 文字 和 其 他 资源 ， 例 如 图 像 、 水 平 线 、Flash 插件 和 其 他 对 象 等 ， 大 多 可 以 通过 插入 面板 
或 搬入 菜单 来 完成 插入 。 

第 五 步 : 发 布 和 维护 更 新 

在 站 点 编辑 完成 后 ， 需 要 将 本 地 的 站 点 同位 于 Internet 服务 右上 的 远 端 站 点 关联 起 来 ， 
把 本 地 设计 好 的 网 站 内 容 传 到 服务 器 上 ， 并 注意 后 期 的 及 时 更 新 和 维护 。 


本 地 站 点 网 站 文件 夹 规划 


在 制作 网 站 之 前 ， 首 先是 把 设计 好 的 网 站 内 容 放置 在 本 地 设计 计算 机 的 硬盘 上 ， 为 了 方 
便 站 点 的 设计 及 上 传 ， 设 计 好 的 网 页 都 应 存储 在 Apache 服务 器 的 安装 路 径 下 (如 本 书 的 路 
径 为 C:\xampp\htdocs 目录 下 ) ， 再 用 合理 的 文件 夹 来 管理 文档 。 在 本 地 站 点 规划 的 时 候 ， 
应 该 注意 如 下 的 操作 规则 。 
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1. 设计 合理 的 文件 夹 

在 本 地 站 点 中 应 该 用 文件 夹 来 合理 构建 文档 的 结构 。 首 先 为 站 点 创建 一 个 主要 文件 夹 ， 
然后 在 其 中 创建 多 个 子 文件 来， 最 后 将 文档 分 类 存储 到 相应 的 文件 夹 下 。 

例如 ， 可 以 在 images 的 文件 夹 中 放置 网 站 页 面 的 图 片 ， 可 以 在 aboutus 文件 夹 中 放置 用 
于 介绍 公司 的 网 页 ， 可 以 在 service 文件 夹 中 放置 关于 公司 产品 方面 的 网 页 。 如 图 2-1 所 示 
是 一 个 大 型 电子 商务 网 站 规划 建立 的 文件 夹 。 

















LEE 
(CION » 计算 机 » Acer(C) » xampp » htdocs » shop » - | 好 | | ££ shop p| 
XHA ”编辑 (E) EEV) 工具 (T) 帮助 (H) 
组 织 ”包含 到 库 中 ”共享 ” ”刻录 。 新 建文 件 夫 H- m e9 
E su n .notes admin 
Ej 最 访问 的 位 置 data images 
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司库 E changeuser. php L3 changeuserpwd.php Lj ehkuser.php 
Bus E chkusernc. php E deleteall.php E endconn.php 
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图 2-1 网 站 在 本 地 硬盘 上 的 文件 夹 建立 





2. 设计 合理 的 文件 名 称 

网 站 建设 要 生成 的 文件 很 多 ， 一 定 要 用 合理 的 文件 名 称 。 这 样 操作 的 目的 其 一 是 为 了 方 
便 在 网 站 的 规模 变 得 很 大 时 ， 可 以 进行 修改 更 新 ; 其 二 是 为 了 方便 浏览 者 看 了 网 页 的 文件 
名 ， 就 能 够 知道 网 页 所 要 表述 的 内 容 。 

在 设计 合理 的 文件 名 时 要 注意 以 下 几 点 。 

(1) 尽量 使 用 短文 件 来 命名 。 

(2) 应 该 避免 使 用 中 文 文件 名 ， 因 为 很 多 Intemet 服务 器 使 用 的 是 英文 操作 系统 ， 不 能 
对 中 文 文件 名 提供 很 好 的 支持 ， 而 且 浏 览 网 站 的 用 户 也 可 能 使 用 英文 操作 系统 ， 中 文 文件 名 
同样 可 能 导致 浏览 错误 或 访问 失败 。 

(3) 建议 在 构建 的 站 点 中 ， 全 部 使 用 小 写 的 文件 名 称 。 很 多 Internet 服务 器 采用 UNIX 
操作 系统 ， 是 区 分 文件 名 大 小 写 的 。 

特别 注意 : 

用 PHP 建立 的 站 点 文件 夹 及 文件 名 一 定 要 使 用 英文 名 称 或 者 数字 名 称 ， 不 要 使 用 中 文 
名 称 ， 否 则 会 导致 Apache 服务 器 不 能 正常 支持 该 站 点 。 

3. 设计 本 地 和 远程 站 点 为 相同 的 文件 结构 

设计 本 地 和 远程 站 点 为 相同 的 文件 结构 是 指 在 本 地 站 点 中 规划 设计 的 网 站 文件 结构 要 同 
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上 传 到 Internet 服务 器 中 被 人 浏览 的 网 站 文件 结构 相同 。 这 样 在 本 地 站 点 上 的 文件 夹 和 文件 
上 的 操作 ， 都 可 以 同 远 程 站 点 上 的 文件 夹 和 文件 一 一 对 应 。Dreamweaver CC 将 整个 站 点 上 传 
到 Intenet 服务 右上， 都 可 以 保证 远程 站 点 是 本 地 站 点 的 完整 的 副本 ,方便 浏览 和 修改 。 


ES 建立 流畅 的 浏览 顺序 ) 


在 网 站 创建 的 时 候 首先 要 考虑 到 网 站 所 有 页 面 的 浏览 顺序 ， 注 意 主 次 页 面 之 间 的 链接 是 
和 否 流畅 。 如 果 采 用 标准 统一 的 网 页 组 织 形式 ， 可 以 让 用 户 轻松 自如 地 访问 每 个 想 要 访问 的 网 
页 。 这 样 能 提高 浏览 的 兴趣 ， 加 大 网 站 的 访问 量 。 建 立 站 点 的 浏览 顺序 ， 要 注意 如 下 几 个 方 
面 的 浏览 顺序 。 

第 一 : 每 个 页 面 建立 首页 的 链接 

在 网 站 所 有 的 页 面 上 ， 都 要 放置 返回 主页 的 链接 。 如 果 在 网 页 中 包含 返回 主页 的 链接 ， 
就 可 以 保证 用 户 在 不 知道 自己 目前 位 置 的 情况 下 ,快速 返回 到 首页 中 ， 重 新 开始 浏览 站 点 中 
其 他 内 容 。 

第 二 : 建立 网 站 导航 

应 该 在 网 站 任何 一 个 页 面 上 建立 网 站 导航 ， 通 过 导航 提供 站 点 的 简明 目录 结构 ， 引 导 用 
户 从 一 个 页 面 快速 进入 到 其 他 的 页 面 上 。 

第 三 : 突出 当前 页 位 置 

在 网 站 页 面 很 多 的 情况 下 ， 往 往 需要 加 入 当前 页 在 网 站 中 的 位 置 说 明 ， 或 者 是 加 入 说 明 
B VIE Bj ul s A T ft FL Bu 9r ABB UR fv EL. MRAMA, Ma A eE 

‘前进 ”和 “后 退 ” 之 类 的 链接 ， 来 帮助 浏览 者 进行 浏览 。 

第 四 : 增加 搜索 和 索引 功能 

对 于 一 些 带 数据 库 的 网 站 ， 还 应 该 给 浏览 者 提供 搜索 的 功能 ， 或 是 给 浏览 者 提供 索引 检 
索 的 权利 ， 使 用 户 快 速 查找 到 自己 需要 的 信息 。 

第 五 : 必要 的 信息 反馈 功能 

网 站 建设 发 布 后 ， 都 会 存在 一 些小 问题 ， 从 浏览 者 那里 及 时 获取 对 网 点 的 意见 和 建议 是 
非常 重要 的 。 为 了 及 时 从 用 户 处 了 解 到 相关 信息 ， 应 该 在 网 页 上 提供 用 户 同 网 页 创作 者 或 网 
站 管理 员 的 联系 途径 。 常 用 的 方法 是 建立 留言 板 或 创建 一 个 E-mail 超级 链接 ， 帮助 用 户 快 
速 将 信息 反馈 到 网 站 中 。 


ETE 定义 本 章 PHP 网 页 测试 网 站 | 


用 Dreamweaver 开发 网 站 之 前 ， 一定 要 先 定 义 网 站 ,利用 Dreamweaver CC“ 站 点 ”一 
“管理 站 点 ”命令 来 进行 管理 。 使 用 Dreamweaver CC 进行 网 页 布局 设计 时 ， 首 先 需 要 用 定义 
站 点 向 导 来 定义 站 点 。 

定义 本 章 所 要 学 习 的 PHP 语法 网 页 的 站 点 具体 操作 步骤 如 下 。 

1) 首先 在 C:\xampp \htdocs 路 径 下 建立 php 文件 夹 ， 如 图 2-2 所 示 ， 本 章 所 有 建立 的 
PHP 程序 文件 都 将 放 在 该 文件 夹 下 。 

2) 打开 Dreamweaver CC， 选 择 菜单 栏 中 的 “站 点 ”一 “管理 站 点 ”命令 ,打开 “管理 
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站 点 ”对 话 框 ， 如 图 2-3 所 示 。 
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图 2-2 建立 站 点 文件 夹 php 
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导入 Business Catalyst 站 点 
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图 2-3 “管理 站 点 ”对 话 框 


3)“ 您 的 站 点 ”列表 框 中 显示 了 所 有 已 经 定义 的 站 点 。 单 击 右 下 角 的 “新 建站 点 ” 按 
钮 ， 打 开 “ 站 点 设置 对 象 ppp” 对话 框 ， 进 行 如 下 参数 设置 。 

“站 点 名 称 ”: php。 

“本 地 站 点 文件 夹 ”: C:\xampp \htdocs\php\。 如 图 2-4 所 示 。 
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高 级 设置 














您 可 以 在 此 处 为 Dreamweaver 站 点 选择 本 地 文件 夹 和 名 称 。 
本 地 站 点 文件 夹 : [Ciwamppmtdocwp o JS 














图 2-4 建立 php 站 点 


4) 单 击 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “ 添 加 服务 器 ”按钮 [ 直 ， 打开 “基本 ” 
选项 卡 ， 进 行 如 图 2-5 所 示 的 参数 设置 。 

“服务 顺 名 称 ”: php。 

“连接 方法 ”: 本 地 /网 络 。 

“服务 器 文件 夹 ” : C:\xampp\htdocs\。 

"Web URL": http://127. 0. 0. 1/php。 








LER] ER | 
服务 器 名 称 : [pho 
连接 方法 : | dd Pe lv 
服务 器 文件 夹 : [C:Wwampp\htdocs je 


Web URL: [http://127.0.0. 1/php 




































































图 2-5 设置 “基本 ”选项 卡 























5) 设置 后 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 ， 单 击 “ 维 护 同步 
信息 ” 复 选 框 ， 在 “服务 器 模型 ”下 拉 列 表 项 中 选择 PHP MySQL 来 表示 是 使 用 PHP 开发 的 
网 页 ， 其 他 的 保持 默认 值 ， 如 图 2-6 所 示 。 

6) 单 击 “保存 ”按钮 ， 返 回 “服务 器 ”设置 对 话 框 ， 再 单 击 勾 选 “测试 ” 复 选 框 ， 如 
图 2-7 所 示 。 

单 击 “ 保 存 ” 按 钮 ， 则 完成 站 点 的 定义 设置 。 在 Dreamweaver CC 中 就 已 经 拥有 了 刚才 
所 设置 的 站 点 了 。 由 于 是 在 本 机 测试 PHP 网 页 ， 因 此 不 需要 设 定 “ 远 程 信息 ”。 设 定好 
“本 地 信息 ”与 “测试 服务 器 ”之 后 ， 单 击 “ 完 成 ”按钮 关闭“ 管理 站 点 ”对 话 杠 ， 这 
样 就 完成 了 Dreamweaver CC 测试 PHP. 网 页 的 网 站 环境 设置 。 
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2-6 设置 “高 级 ”选项 卡 














EN 您 将 在 此 位 置 选择 承载 web 上 的 页 面 的 服务 器 。 此 对 话 框 的 设置 来 自 
版 本 控制 Internet 服务 提供 商 (ISP) 或 web 管理 员 。 


高 级 设置 











:要 开始 在 Dreamweaver 站 点 上 工作 ， 您 无 需 完成 此 步骤 。 如 果 要 连接 到 web 并 发 
TE» 您 只 需 定义 一 个 远程 服务 器 即 P]。 
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2-7 勾 选 “测试 ” 复 选 杠 











| Section. 
PHP 程序 编写 基础 





如 果 读 者 对 ASP 或 者 JSP 有 所 了 解 ， 应 该 知道 在 编写 这 些 网 页 程序 时 ， 可 以 将 HTML 
标记 与 这 些 动态 语言 代码 混合 到 一 个 文件 中 。 然 后 使 用 特殊 的 标识 (符号 “<%%>”) 将 
两 者 区 别 开 来 。PHP 也 是 如 此 ， 可 以 与 HTML 标记 共存 ，PHP 提供 了 多 种 方式 来 与 HTML 
标记 区 别 ， 用 户 可 以 根据 自己 的 喜好 选择 一 种 ， 也 可 以 同时 使 用 几 种 。 本 节 将 介绍 PHP 的 
基础 程序 结构 ， 包 括 输出 和 注释 的 方法 。 
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4. PHP 程序 结构 


PHP 语句 与 Perl 和 C 一 样 ， 结 构 比较 严 着 需要 在 每 条 语句 后 使 用 分 号 “;” 表 示 结 O) 
束 ， 而 且 对 语句 中 的 大 小 写 敏 感 。 
常用 的 方式 有 如 下 3 种 。 
方法 1: PHP 标准 结构 ( 推 

<? php 
echo " hello, 你 好 ,这 是 我 的 第 一 个 PHP 程序 !" ; 
T 
方法 2: PHP 的 简短 风格 (需要 设置 php. ini) 
<? echo "hello, 你 好 ,这 是 我 的 第 一 个 PHP 程序 1" ;? > 
方法 3: PHP 的 SCRIPT 风格 (元 长 的 结构 ) 
< script language = " php" > echo" hello ,你 好 ,这 是 我 的 第 一 个 PHP 程序 1" ; < /script > 


3 种 方法 输出 的 结果 是 一 样 的 ， 在 Dreamweaver 里 编辑 后 输出 的 结果 如 图 2-8 所 示 。 


F PHP 程 序 结 档 - Hicrosoft Internet Explorer 
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PHP 代 码 + 注释 


PHF 标 准 结构 推荐 ) 
<?php 
echo "hello, 你 好 ， 这 是 我 的 第 一 个 FHF 程序 1"; 


FHP 的 简短 风格 (需要 设置 php. ini) 
<? echo "hello, 你 好 ， 这 是 我 的 第 一 个 PEE 程序!" ; ?> 


PHP 的 SCRIPT 风 格 〔 元 长 的 结构 ) 
<script language="php“> echo“hello, 你 好 ， 这 是 我 的 第 一 个 PHP 程 序 !" ;</script> 








A Internet 





图 2-8 输出 结果 


实际 开发 时 ， 第 1 种 和 第 2 种 是 最 常用 的 方法 ， 即 使 用 小 于 号 加 上 问号 之 后 跟 PHP 代 
码 ， 在 程序 代码 的 最 后 ， 使 用 问号 及 大 于 号 表示 结束 ， 而 第 3 种 方法 有 点 类 似 于 JavaScript 
的 编写 方式 。 


su PHP 输出 结果 


在 PHP 中 输出 信息 可 以 用 echo( ) 命令 ，echo( ) 不 是 一 个 函数 〈 它 是 一 个 语言 结构 ) ， 
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因此 不 一 定 要 使 用 小 括号 来 指明 参数 ， 单 引号 、 双 引号 都 可 以 。echo( ) (不 像 其 他 语言 结 
TJ) 表现 得 不 像 一 个 函数 ， 所 以 不 能 总 是 使 用 一 个 函数 的 上 下 文 。 另 外 ， 如 果 想 给 echo() 
传递 多 个 参数 ， 那 么 就 不 能 使 用 小 括号 。 

提示 : 

也 可 以 使 用 print( ) 命 令 来 实现 ， 但 echo( ) 命 令 比 print( ) 函数 快 一 点 。 

用 PHP 输出 语句 ， 包 括 HTML 格式 化 标签 ， 如 图 2-9 所 示 。 


F PHP 语 句 答 出 - Kicrosoft Internet Explorer 
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PHP 基 础 语法 实例 返回 


PHP 代 码 + 注释 


(php 
echo "4p»fKRI B] Hot. SEXE ER. Cp": 





d Internet 














图 2-9 使 用 echo 输出 字符 

















75 PHP 程序 注释 


PHP 中 可 以 使 用 以 多 种 风格 的 注释 方式 。 
/* 第 1 种 PHP 注释 适合 用 于 多 行 */ 
// 第 2 种 PHP 注释 适合 用 于 单行 
# 第 3 种 PHP 注释 适合 用 于 单行 
多 行 注释 和 C、C ++ 和 Shell 的 注释 风格 一 样 ， 以 A * 开始 ，* /结束 ， 例 如 : 


<? php 

/* 

注释 :关于 本 段 程序 的 说 明 

该 段 程 序 主 要 用 于 建立 数据 库 的 连接 ...... 





*/ 
?> 

单行 注释 〈 有 /和 # 这 两 种 ) : 
<? php 


echo "说 明 " ;// 输 出 说 明 二 字 
echo "说 明 " ;# 输出 说 明 二 字 


7» 


动态 网 站 开发 从 入 门 到 精通 
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注意 ， 注 释 符号 只 有 在 <? php ? > 里 才 会 起 到 应 有 的 效果 。 


空 制 动态 输出 字符 


在 实际 的 网 页 设计 过 程 中 ， 单 使 用 echo( ) 命令 并 不 能 满足 实际 的 应 用 ， 如 需要 输出 随 
机 的 数字 ， 控 制 字 符 串 的 大 小 写 以 及 一 些 特殊 的 字符 处 理 等 常用 操作 ， 都 可 以 通过 调用 相应 
的 函数 命令 加 以 实现 。 


JL PHP 也 数 的 调用 


如 果 要 实现 相应 的 字符 控制 就 需要 调用 相应 的 函数 命令 ， 在 PHP 编程 中 调用 相应 的 也 
数 还 是 比较 简单 的 ， 如 使 用 rand( ) 函数 来 产生 一 个 随机 数字 (范围 是 0 ~100)。 


<? php 
echo rand(0,100) ; 
7» 


刷新 便 可 看 到 输出 结果 的 变化 ，rand 函数 中 的 0 和 100 为 指定 给 rand. 函数 的 参数 ， 前 
面 的 0 就 意味 着 最 小 可 能 出 现 的 数值 为 零 ，100 则 意味 着 最 大 可 外 Lun m 
Kj 2-10 所 示 。 很 多 函数 都 有 必 选 或 可 选 的 参数 。 
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PHP 基 础 语法 实例 


PHP 代 码 + 注释 


使 用 rand 中 函数 来 产生 一 个 随机 数字 (范围 是 0 到 100); 


<?php 


echo rand(0, 100) ; 

?» 

Sr Ee RD dr b 8 RED SE E, randi SP E 00 100 为 指定 给 rand 函 数 的 参数 , 前 面 的 0 就 意味 着 最 小 可 
能 出 现 的 数值 为 地 ，100 则 意味 着 最 大 可 能 出 现 的 数 俐 为 100， 很 多 函数 都 有 必 选 或 是 可 选 的 参数 。 








图 2-10 输出 随机 函数 的 结果 


JOD 截 去 字符 串 首尾 


使 用 trim 函数 可 以 返回 去 除 字符 串 string 首尾 的 空白 字符 后 的 字符 串 。 
语法 : string trim( string str) ; 

返回 值 : 字符 串 

函数 种 类 : 资料 处 理 
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动态 网 站 开发 从 入 门 到 精通 


在 使 用 HTML 表单 信息 之 前 ,一 般 都 会 对 这 些 数据 做 一 些 整 理 。 
<? php 
// 清 理 字符 串 中 开始 和 结束 位 置 的 多 余 空 格 
$name =" 12356789 "; 


























$name = trim( $name) ; 
echo $name; 


7» 


运行 的 结果 可 以 将 前 后 的 空白 去 除 。 


UR 格式 化 输出 字符 


nl2br( ) 函数 可 以 将 换行 字符 转换 成 HTML 换行 的 <br > 指令 。 
语法 : string nl2br( string string) ; 

返回 值 : 字符 串 

函数 种 类 : 资料 处 理 


举例 如 下 : 
<? php 
$str = "今天 的 天 气 特别 好 ,心情 也 不 错 , 决 定 去 学 校 足 球场 ,好 好 地 踢 一 场 球 。" ; 
echo $str; 


echo " <br/>"; 
echo nl2br( $str) ; 
7» 


输出 的 结果 如 图 2-11 所 示 。 
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PHP 基 础 语法 实例 返回 


说 明 

nl2br0 函 数 可 将 字符 串 中 的 换行 符 转 成 HTML 的 换行 符号 
<?php 

$str =“ 今 天 的 天 气 特 别 好 ， 心 情 也 不 错 ， 
决定 去 学 校 足球 场 ， 好 好 地 踢 一 场 球 。"; 

echo $str; 

echo “<br />"; 


echo nl2br($str): 


今天 的 天 气 特别 好 ， 心 情 也 不 错 ， 决 定 去 学 校 足 球场 ， 好 好 地 踢 一 场 球 。 
今天 的 天 气 特 别 好 ， 心 情 也 不 错 ， 
决定 去 学 校 足 球场 ， 好 好 地 踢 一 场 球 。 











图 2-11 格式 化 输出 字符 的 结 


PHP 编 程 基础 


esp 打印 格式 化 输出 


printf( ) 在 实现 echo 功能 的 同时 能 返回 值 (True 或 False， 表 示 是 否 成 功 ) ， 还 可 以 实现 人 人) 
更 复杂 的 格式 。 
语法 : int printf( string format,mixed [args]... ); 
返回 值 : 整数 
函数 种 类 : 资料 处 理 


<? php 

$num = 12. 8; 

// 将 $num 里 的 数值 以 字符 串 的 形式 输出 
printf(" 数 值 为 :%s" , $num); 
echo " <br/>"; 

// 转 换 成 为 带 有 2 位 小 数 的 浮 点 数 
printf(" 数值 为 :%. 2f" , $num); 
echo " <br/>"; 

// 解 释 为 整数 并 作为 二 进 制 数 输出 
printf(" 数值 为 :%b" , $num); 
echo " <br/>"; 
// 打 印 % 符 号 

printf(" 数值 为 :% 96 96s" , $num); 
7» 


输出 的 结果 如 图 2-12 所 示 。 











J 打印 将 式 化 葵 出 - 了 icrosoft Internet Explorer BEE 
TED WAO SEV KEA IAM) 800 L3 


Om- O- NAQL zE 6 A RBE 
地 址 0) [Æ] http://127. 0. 0. 1/php/PHP/PHP printf. php < 输入 关键 词 搜索 MERA E Q snet E 








printf ("数值 为 :%. 2£", $num) ; 
echo “<br /> : 


/1 解释 为 整数 并 作为 二 进 制 数 输出 
printf ("数值 为 :%b", $num) ; 
echo “<br />"; 


打印 % 符 号 
printf ("数值 为 :%%%s”, $num) ; 


输出 结果 
数值 为 :12.8 
数值 为 :12.80 
数值 为 :1100 
数值 为 :%12.8 
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图 2-12 打印 格式 化 输出 结果 
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USES 字母 大 小 写 转 换 


字母 的 大 小 写 转换 在 PHP. 网 页 页 面 切换 中 经 常 使 用 到 ， 涉 及 的 函数 命令 有 以 下 儿 个 常 
用 的 ， 如 strtoupper( ) 可 以 将 字符 串 转 换 成 大 写字 母 ， 将 每 个 单词 的 第 一 个 字母 变 大 写 可 以 
使 用 ucwords( ) ， 将 字符 串 的 第 一 个 字母 转 成 大 写 可 以 使 用 ucfirst( ) ， 将 字符 串 转换 成 小 写 
字母 可 以 使 用 strtolower( ) 。 举 例如 下 。 


<? php 











$str = "I like this game!" ; 

// 将 字符 串 转 换 成 大 写字 母 

echo strtoupper( $str). " <br/>"; 
// 将 字符 串 转 换 成 小 写字 母 

echo strtolower( $str). " <br/>"; 
// 将 字符 串 的 第 一 个 字母 转 成 大 写 
echo ucfirst( $str). " <br/>"; 

// 将 每 个 单词 的 第 一 个 字母 变 大 写 
echo ucwords( $str) ; 


7» 
输出 的 结果 如 图 2-13 所 示 。 
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说 明 


<?php 
$str = "I like this game!” ; 
/将 字符 串 转换 成 大 写字 母 


echo strtoupper($str)."4br /5"; 


/将 字符 串 转换 成 小 写字 母 
echo strtolower($str)."4br />"; 


BA RHRISIE— 1 EEHERCKS 


echo ucfirst($str)."4br /5"; 


/将 每 个 单词 的 第 一 个 字母 变 大 写 
echo ucwords($str): 
2» 


输出 结果 
I LIKE THIS GAME! 
i like this game! 
l like this game! 
I Like This Game! 
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图 2-13 字母 转换 大 小 写 结果 
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USES 处 理 特殊 的 字符 


有 些 字符 对 于 MySQL 是 有 特殊 意义 的 ， 比 如 引号 、 反 斜 杜 和 NULL 字符 。 那 么 如 何 正 
确 处 理 这 些 字符 呢 ? 可 以 使 用 addslashes ( ) 函数 和 stripslashes( ) 函数 ，PHP5.3.0 以 下 的 版 
本 中 默认 是 开启 魔术 引号 的 magic_quotes_gpc。PHP5. 3. 0 起 废弃 并 将 自 PHPS. 4. 0 起 移 除 








<? php 

$str=" V'' \ NULL" ; 

echo $str. " <br/>"; 

echo addslashes( $str). " <br/>"; 
echo stripslashes( $str). " <br/>"; 
7» 


输出 的 结果 如 图 2-14 所 示 。 
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说 明 

有 些 字符 对 于 MySQL 是 有 特殊 意义 的 ， 比 如 引号 、 反 斜 杠 和 NULL 宇 符 ， 如 何 正确 处 理 这 些 字符 ? 
我 们 可 以 使 用 addslashes0 函 数 和 stripslashes0 函 数 ， PHP5 中 默认 是 开启 麻 术 引号 的 magic quotes gpce 
<?php 

$str =” V" XN NULL"; 

echo $str."4br />"; 

echo addslashes($str)."4br /?"; 

echo stripslashes($str)."4br /5": 














输出 结果 
”ANULL 
VY NULL 
"' NULL 











图 2-14 处 理 特殊 的 字符 





表单 变量 的 使 用 


在 HTML 中， 表单 拥有 一 个 特殊 功能 : 它们 支持 交互 作用 。 除 了 表单 之 外 ， 几 乎 所 有 
的 HTML 元 素 都 与 设计 以 及 展示 有 关 ， 只 要 愿意 就 可 将 内 容 传 送 给 用 户 。 另 一 方面 ， 表 单 
为 用 户 提供 了 将 信息 传送 回 Web 站 点 创建 者 和 管理 者 的 可 能 性 。 如 果 没 有 表单 ，Web 就 是 
一 个 静态 的 网 页 图 片 。 对 于 PHP. 的 动态 网 页 开发 ， 经 常 遇 到 使 用 表单 变量 对 象 ， 通 常 有 
POST( ) 和 GETO 两 种 方法 ， 这 和 其 他 动态 语言 开发 的 命令 是 一 样 的 。 本 小 节 就 介绍 表单 变 
量 的 使 用 方法 。 













作为 用 于 设置 处 理 表单 数据 的 类 型 ， 
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2 POST 表单 变量 


POST 是 系统 的 默认 值 ， 表 示 将 数据 表单 的 数据 提 


动态 网 站 开发 从 入 门 到 精通 





交 到 “动作 ”属性 设置 的 文件 中 进行 处 理 。 假 设 有 一 个 HTML 表单 用 method = " post" 的 方 


全 


式 传递 给 本 页 一 个 name =" test" 的 文字 信息 ， 
量 ， 如 图 2-15 所 示 。 


< form method > ="post" action ="" > 


可 用 三 种 风格 的 表单 变量 来 显示 这 个 表单 变 





< input type = "text" size ="20" name = "test"/ > 


< input type = " submit" value = "提交 变量 "/ > 
< form > 
<? php 


Echo $test; 

echo $. POST| "test" ] ; 

echo $HTTP. POST. VARS[ " test" ] ; 
?> 
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// 简 短 格式 , 需 配置 php. ini 中 的 默认 设置 
// 中 等 格式 ,推荐 使 用 这 种 方式 
// 宛 长 格式 
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<form method="post“ action=““> 

<input type="text" size="20" name-"test" /> 
<input type="submit” value=“ RTE" /> 
</form> 

<?php 

if (isset ($_POST[ test’ ])) 

echo $ POST[' test']: 


C 本 
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2-15 POST 表单 测试 


GET 和 POST 的 主要 区 别 : 
1) 数据 传递 的 方式 以 及 大 小 。 


2) GET 会 将 传递 的 数据 显示 在 ul 地 址 上 ，POST 则 不 会 。 
3) GET 传递 数据 有 限制 ， 一 般 大 量 数据 都 得 使 用 POST 方法 。 


EVE GET 表单 变量 


GET 表示 追加 表单 的 值 到 URL 并 且 发 送 服 务 器 请 求 ， 对 于 数据 量 比 较 大 的 长 表单 最 好 





不 要 用 这 种 数据 处 理 方式 。 


PHP 编 程 基础 


假设 有 一 个 HTML 表单 用 method = " get" 的 方式 传递 给 本 页 一 个 name = "test" 的 文字 信 
息 ， 可 用 3 种 风格 的 表单 变量 来 显示 这 个 表单 变量 。 











<? php 

Echo $test; // 简 短 格式 ,需要 配置 php. ini 中 的 默认 设置 > 
echo $. GET[ "test" ] ; // 中 等 格式 ,推荐 使 用 此 方法 

echo $HTTP_GET_VARS[ "test" ] ; /7 宛 长 格式 

7» 


如 图 2-16 所 示 的 结果 ， 在 “输出 结果 ” 文 框 中 输入 数字 值 123456 ， 然 后 单 击 “ 提 交 变 
量 ”按钮 ， 则 IE 地 址 栏 里 显示 了 表单 变量 传递 的 值 “test = 123456”。 
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<form method-"get" action=""> 

<input type="text” size=“20" name="test” /> 
<input type="submit” value- EAEE" /> 
</form> 

?php 


if (isset ($_GET[ test’ ])) 
echo $ GET[' test']: 














123456 











图 2-16 GET 表单 测试 


UCM 字符 捉 的 连接 


在 PHP 程序 里 想 让 多 个 字符 串 进行 连接 ， 就 要 用 到 一 个 (. )“ 点 ”号 ,来 看 如 下 的 例子 。 


<? php 


$ website = " baidu" ; 


echo $ website. ". com" ; 


7» 


上 面 的 输出 结果 就 是 baidu. com, 
有 一 种 情况 ， 当 echo 后 面 使 用 的 是 (") 双 引 号 ， 可 以 同样 达到 如 上 的 效果 。 


<? php 
$ website = " baidu" ; 
echo " $website. com" ; ”// 双 引号 里 的 变量 还 是 可 以 正常 显示 出 来 , 并 和 一 般 的 字符 串 自 动 区 分 开 来 


7» 
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但 如 果 是 单 引号 的 话 ， 就 会 将 里 面 的 内 容 完 全 以 字符 串 形式 输出 给 浏览 


<? php 
$ website = " baidu. com" ; 
echo $website. com ; 


7» 


将 显示 $ website. com, 





常量 和 变量 








常量 和 变量 是 编程 语言 的 最 基本 构成 ， 代 表 了 运算 中 所 需要 的 各 种 值 。 通 过 变量 和 常 
量 ， 程 序 才 能 对 各 种 值 进行 访问 和 运算 。 学 习 常量 和 变量 是 编程 的 基础 。 常 量 和 变量 的 功能 
就 是 用 来 存储 数据 的 ， 但 区 别 在 于 常量 一 旦 初始 化 就 不 再 发 生变 化 ， 可 以 理解 为 符号 化 的 常 
数 。 本 小 节 就 介绍 一 下 PHP 中 的 常量 和 变量 。 


UL PHP 中 的 常量 


常量 是 指 在 程序 执行 过 程 中 无 法 修改 的 值 。 在 程序 中 处 理 不 需要 修改 的 值 时 ， 常 量 非常 
有 有 用， 例如， 定义 圆周 率 PI。 常 量 一 旦 定义 ， 在 程序 的 任何 地 方 都 不 可 以 修改 ,但 是 可 以 
在 程序 的 任何 地 方 访问 。 

在 PHP 中 使 用 define() 函数 定义 常量 ， 函 数 第 1 个 参数 表示 常量 名 ， 第 2 个 参数 表示 和 党 
量 的 值 。 

例如 ， 下 面 定 义 一 个 名 为 HOST 的 常量 ， 如 图 2-17 所 示 。 











<? php 
define( " HOST" ," www. baidu. com" ) ; / / KAE“ www. baidu. com" 赋予 常 量 HOST 
echo HOST; // 输 出 HOST 常量 的 值 
dx 
常量 说 明 如 下 。 


常量 默认 区 分 大 小 写 ， 按 照 惯例 ， 常 量 标识 符 总 是 大 写 。 常 量 名 和 其 他 任何 PHP 标记 
遵循 相同 的 命名 规则 。 合 法 的 常量 名 以 字母 或 下 夯 线 开始 ， 后 面 跟 任何 字母 、 数 字 或 下 
画 线 。 

PHP 的 系统 常量 包括 5 个 魔术 常量 和 大 量 的 预定 义 常 量 。 

魔术 常量 会 根据 使 用 的 位 置 而 改变 ，PHP 提供 的 5 个 魔术 常量 分 别 是 : 

1) _LINE_: 表示 文件 中 的 当前 行 号 。 

2) _FILE_: 表示 文件 的 完整 路 径 和 文件 名 。 如 果 用 在 包含 文件 中 ， 则 返回 包含 文件 名 。 
自 PHP 4.0.2 起 ，_FILE 总 是 包含 一 个 绝对 路 径 ， 而 在 此 之 前 的 版 本 有 时 会 包含 一 个 相对 
路 径 。 

3) FUNCTION . 表示 函数 名 称 (PHP 4.3.0 新 加 ) 。 自 PHP 5 起 本 常量 返回 该 函数 被 
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代码 


?php 
define ("HOST", "www. baidu. com") HIE “ww. baidu. com" WTE HOST 
echo HOST; //% H HOST Æ B) 1B 


输出 结果 


www.baidu.com 














图 2-17 定义 常量 











定义 时 的 名 字 (区 分 大 小 写 )。 在 PHP 4 中 该 值 总 是 小 写字 母 的 。 

4) CLASS ; 表示 类 的 名 称 (PHP 4.3.0 新 加 )。 自 PHP 5 起 本 常量 返回 该 类 被 定义 时 
的 名 字 (区 分 大 小 写 ) 。 在 PHP 4 中 该 值 总 是 小 写字 母 的 。 

5) METHOD : 表示 类 的 方法 名 (PHP 5.0.0 新 加 ) 。 返 回 该 方法 被 定义 时 的 名 字 (区 
分 大 小 写 ) 。 

预定 义 常 量 又 分 为 内 核 预 定义 常量 和 标准 预定 义 常量 两 种 ， 内 核 预 定义 常量 在 PHP 的 
内 核 、Zend 引擎 和 SAPI 模块 中 定义 ， 而 标准 预定 义 常 量 是 PHP 默认 定义 的 ， 比 如 常用 的 
E ERROR, E. NOTICE, E ALL 等 。 


Uu PHP 中 的 变量 


在 PHP 中 ,创建 一 个 变量 首先 需要 定义 变量 的 名 称 。 变 量 名 区 分 大 小 写 ， 总 是 以 $ 符 
号 开头 然后 是 变量 名 。 如 果 在 声明 变量 时 ， 忘 记 变 量 前 面 的 $ 符 号 ， 那么 该 变量 将 无 效 。 
在 PHP 中 设置 变量 的 正确 方法 如 下 所 示 。 











$var_name = value; 


在 PHP 中， 可 以 使 用 值 赋值 和 引用 赋值 这 两 种 方法 为 变量 赋值 。 
值 赋值 是 直接 把 一 个 数值 通过 赋值 表达 式 传递 给 变量 。 值 赋值 是 一 种 常量 的 变量 赋值 的 
方法 ， 其 使 用 格式 如 下 所 示 。 





<? php 

$name =" baidu" ; /有效 变量 

$ Name = " website" ; // 有 效 变 量 

echo " $name, $Name" ; //[ 输 出 为 “baidu , website" 
$1website = " www. baidu. com" ; // 无 效 变量 ,以 数字 开始 









PHP*MySQL*Dreamweaver 动态 网 站 开发 从 入 门 到 精通 
$_1website =" www. baidu. com" ; // 有效 变 量 








从 上 述 代码 中 可 以 看 到 ,在 PHP 中 不 需要 在 设置 变量 之 前 声明 该 变量 的 类 型 ， 而 是 根 
据 变量 被 设置 的 方式 ，PHP 会 自动 把 变量 转换 为 正确 的 数据 类 型 。 

在 PHP 中， 变量 的 命名 规则 有 如 下 几 点 。 

1) 变量 名 必须 以 字母 或 下 画 线 " "开头 。 

2) 变量 名 只 能 包含 字母 、 数 字 、 字 符 以 及 下 画 线 。 

3) 变量 名 不 能 包含 空格 。 如 果 变 量 名 由 多 个 单词 组 成 ， 那 么 应 该 使 用 下 画 线 进行 分 隔 
(例如 $my_string) ， 或 者 以 大 写字 母 开 头 〈 例 如 $myString) 。 

在 PHP 中 ， 还 支持 另 一 种 赋值 方式 ， 称 为 变量 的 引用 赋值 ， 例 如 下 面 的 示例 。 






































<? php 

$wo-2 baidu ; // 为 变量 $ wo 赋值 

$ba-& $wo; // 取 变量 $ba 引用 了 变量 $wo 的 值 

$ba =" Web site is $ba" ; // 修 改变 量 $ba 的 值 

echo $ wo; // 结 果 为 “Web site is baidu” 

echo $ba; // 变 量 $ba 的 值 也 被 修改 ,结果 与 $ba 相同 
7» 


从 这 里 可 以 看 出 ， 对 一 个 变量 值 的 修改 将 会 导致 另外 一 个 变量 值 被 修改 。 从 本 质 上 讲 ， 
变量 的 引用 赋值 导致 两 个 变量 指向 同一 个 内 存 地 址 。 因 此 ， 不 论 对 哪 一 个 变量 进行 修改 ， 修 
改 的 是 同一 个 内 存 地 址 中 的 数据 ， 从 而 出 现 同 时 被 修改 的 结 

PHP 提供 了 大 量 的 预定 义 变量 ， 这 些 变量 在 任何 范围 内 自动 生效 ， 因 此 通常 也 被 称 为 
自动 全 局 变量 (autoglobals) 或 者 超 全 局 变量 (superglobals) (PHP 中 没有 用 户 自 定义 超 全 
局 变量 的 机 制 ) 。 在 PHP 4. 1. 0 之前， 如 使 用 超 全 局 变量 ， 要 么 依赖 register_globals ， 要 么 就 
是 长 长 的 预定 义 PHP 数组 ( SHTTP * VARS), H PHP 5.0.0 起 , 长 格式 的 PHP 预定 义 
变量 可 以 通过 设置 register. long arrays 来 屏蔽 。 

常用 的 超 全 局 变量 如 下 。 

1) $GLOBALS: 表示 包含 一 个 引用 指向 每 个 当前 脚本 的 全 局 范围 内 有 效 的 变量 ， 该 数 
组 的 键 名 为 全 局 变量 的 名 称 。 从 PHP 3 开始 存在 $GLOBALS 数组 。 

2) $ SERVER; 表示 变量 由 Web 服务 器 设 定 或 者 直接 与 当前 脚本 的 执行 环境 相关 联 ， 
类 似 于 旧 数 组 $HTTP_SERVER_VARS 数组 (依然 有 效 ， 但 反对 使 用 ) 。 

3) $ GET; 表示 经 由 URL 请 求 提交 至 脚本 的 变量 ， 类 似 于 旧 数 组 $HTTP_CET_VARS 
数组 (依然 有 效 ， 但 反对 使 用 ) 。 

4) $_POST: 表示 经 由 HTTP POST 方法 提交 至 脚本 的 变量 ， 类似 于 旧 数 组 $ HTTP_ 
POST VARS 数组 (依然 有 效 ， 但 反对 使 用 ) 。 

5) $_COOKIE: 表示 经 由 HTTP COOKIE 方法 提交 至 脚本 的 变量 ,类似 于 旧 数 组 $HTTP 
_COOKIE_VARS 数组 (依然 有 效 ， 但 反对 使 用 ) 。 

6) $ FILES; 表示 经 由 HTTP POST 文件 上 传 而 提交 至 脚本 的 变量 。 类 似 于 旧 数 组 
$HTTP POST FILES 数组 (依然 有 效 ， 但 反对 使 用 ) 。 

7) $_ENV: 表示 执行 环境 提交 至 脚本 的 变量 ,类似 于 旧 数 组 $HTTP_ENV_VARS 数组 
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(依然 有 效 ， 但 反对 使 用 ) 。 

8) $ REQUEST; 表示 经 由 GET, POST 和 COOKIE 机 制 提交 至 脚本 的 变量 ， 因 此 该 数 
组 并 不 值得 信任 。 所 有 包含 在 该 数组 中 的 变量 的 存在 与 否 以 及 变量 的 顺序 均 按 照 php. ini 中 
的 variables_order 配置 指示 来 定义 。 此 数组 在 PHP 4. 1.0 之 前 没有 直接 对 应 的 版 本 。 

9) $ SESSION; 表示 当前 注册 给 脚本 会 话 的 变量 ， 类 似 于 旧 数 组 $ HTTP_SESSION_ 
VARS 数组 (依然 有 效 ， 但 反对 使 用 ) 。 





"Ls PHP 数据 类 型 


数据 是 程序 运行 的 基础 ， 所 有 的 程序 都 是 在 处 理 各 种 数据 。 例 如 ， 财 务 统计 系统 所 要 处 
理 的 员工 工资 额 、 论 坛 程序 所 要 处 理 的 用 户 名 、 密 码 、 用 户 发 帖 数 等 等 ， 所 有 这 些 都 是 数 
据 。 在 编程 语言 中 ， 为 了 方便 对 数据 的 处 理 以 及 节省 有 限 的 内 容 资源 ， 需 要 对 数据 进行 分 
类 。PHP 支持 7 种 原始 类 型 ， 分 别 有 如 下 几 种 。 
1) boolean (布尔 型 True/False) 。 
2) integer. (整数 类 型 ) 。 
3) float ( 浮 点 型 ， 也 称 为 double， 可 用 来 表示 实数 ) 。 
4) string (字符 串 类 型 ) 。 
5) array (数组 同一 变量 保存 同类 型 的 多 条 数据 ) 。 
6) object (对 象 ) 。 
7) 特殊 类 型 (resource 资源 和 NULL 未 设 定 ) 。 
下 面 介 绍 常用 的 数据 类 型 。 
1. 布尔 型 boolean 
布尔 型 是 最 简单 的 类 型 ， 它 表达 了 真 值 ， 可 以 为 True 或 False。 要 指定 一 个 布尔 值 ， 使 
用 关键 字 True zX False, Jf E. True 或 False 不 区 分 大 小 写 。 例 如 ; 
$pay = True; /给 变量 $pay 赋值 为 True 
某 些 运算 通常 返回 布尔 值 ， 并 将 其 传递 给 控制 流程 。 比 如 用 比较 运算 符 ( == ) 来 比较 
两 个 运算 数 ， 如 果 相 等 ， 则 返回 True, AURE False， 代 码 如 下 : 
if( $A == $B) | 
echo " $A 5 $B 相等 " ; 
| 
对 于 如 下 的 代码 : 
if( $pay == True) | 
echo " Ef" ; 
} 
可 以 使 用 下 面 的 代码 代替 : 
if( $pay) | 
echo "已 付 "，; 
| 
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转换 成 布尔 型 用 bool 或 者 boolean 来 强制 转换 。 但 是 很 多 情况 下 不 需要 用 强制 转换 , 
为 当 运算 符 、 函 数 或 者 流程 控制 需要 一 个 布尔 参数 时 ， 该 值 会 被 自动 转换 。 

当 转 换 为 布尔 型 时 ， 以 下 值 被 认为 是 False。 

1) 布尔 值 False。 

2) 整 型 值 0 ( 零 ) 。 

3) 浮 点 型 值 0.0 (F), 

4) 空白 字符 串 和 字符 串 "0" 。 

5) 没有 成 员 变 量 的 数组 。 

6) 没有 单元 的 对 象 ( 仅 适 用 于 PHP 4) 。 

7) 特殊 类 型 NULL (包括 尚未 设 定 的 变量 ) 。 

所 有 其 他 值 都 被 认为 是 True (包括 任何 资源 ) 。 

2. ZA! integer 

一 个 整数 是 集合 Z=|…, -2,-1,0,1,2,…} 中 的 一 个 数 。 整 型 值 可 以 用 十 进 制 、 十 六 
进 制 或 八进制 表示 ， 前 面 可 以 加 上 可 选 的 符号 ( -或 者 + )。 如 果 用 八进制 ,数字 前 必须 加 
上 0 (E); 用 十 六 进 制 ， 数 字 前 必须 加 上 0x。 整 型 数 的 字 长 和 平台 有 关 ， 通 常 最 大 值 是 大 
约 二 十 亿 (32 位 有 符号 ) 。PHP 不 支持 无 符号 整数 。 如 果 给 定 的 一 个 数 超出 了 整 型 的 范围 ， 
将 会 被 解释 为 浮 点 型 同样 如 果 执 行 的 运算 结果 超出 了 整 型 范围 ， 也 会 返回 浮 点 型 。 

要 将 一 个 值 转换 为 整 型 ， 用 int 或 integer 强制 转换 即 可 。 不 过 大 多 数 情 况 下 都 不 需要 强 
制 转换 ， 因 为 当 运 算 符 、 函 数 或 流程 控制 需要 一 个 整 型 参数 时 ， 该 值 会 自动 转换 。 还 可 以 通 
过 函数 intval( ) 来 将 一 个 值 转换 成 整 型 。 

从 布尔 型 转换 成 整 型 ，False 将 产生 出 0，True 将 产生 出 1。 当 从 浮 点 数 转换 成 整数 时 ， 
数字 将 被 取 整 (丢弃 小 数位 ) 。 如 果 浮 点 数 超出 了 整数 范围 ， 则 结果 不 确定 ， 因 为 没有 足够 
的 精度 使 浮 点 数 给 出 一 个 确切 的 整数 结 

3. 浮 点 型 float 


浮 点 数 也 叫 双 精 度数 或 实数 ， 可 以 用 以 下 任何 语法 定义 : 
































<? php 
$a=1.234; 
$b 21.263; 
$c=7E-10; 
7» 
浮 点 数 的 字 长 和 平台 相关 ， 通 常 最 大 值 是 1. 8e308 ， 并 具有 14 位 十 进 制 数字 的 精度 。 
4. 字符 串 string 
字符 串 是 由 引号 括 起 来 的 一 些 字符 ， 常 用 来 表示 文件 名 、 显 示 消 息 、 输 入 提示 符 等 。 字 
符 串 是 一 系列 字符 ， 字 符 串 的 大 小 没有 限制 。 字 符 串 可 以 用 单 引号 、 双 引号 或 定 界 符 3 种 方 
法 定义 。 下 面 分 别 介绍 这 3 种 方法 。 
1) 单 引 号 。 指 定 一 个 简单 字符 串 的 最 简单 的 方法 是 用 单 引号 〈 ) 括 起 来 。 例 如 : 


























<? php 
echo Hello World ; /输出 为 :Hello World 


动态 网 站 开发 从 入 门 到 精通 





PHP 编 程 基础 
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如 果 字 符 串 中 有 单 引 号 ， 要 表示 这 样 一 个 单 引 号 ， 和 很 多 其 他 语言 一 样 ， 需 要 用 反 斜 线 
(VO 转 义 。 例 如 : 
<? php 
echo IV m Tom ; /输出 为 :TDm Tom 


7» 


如 果 在 单 引 号 之 前 或 字符 串 结尾 需要 出 现 一 个 反 斜 线 (\ ) ， 需 要 用 两 个 反 和 斜 线 (NN) R 
示 。 例 如 : 








<? php 
echo Path is c:\windows\system\\ ; // 输出 为 :Path is c:\windows\system\ 
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对 于 单 引 号 〈 ) 括 起 字符 串 ，PHP 只 懂得 单 引号 和 反 斜 线 的 转 义 序列 。 如 果 试 图 转 义 
任何 其 他 字符 ， 反 斜 线 本 身 也 会 被 显示 出 来 。 另 外 ， 还 有 不 同 于 双 引 号 和 定 界 符 的 很 重要 的 
一 点 就 是 ， 单 引号 字符 串 中 出 现 的 变量 不 会 被 解析 。 

2) 双 引 号 。 如 果 用 双 引 号 (") 括 起 字符 串 ，PHP 懂得 更 多 特殊 字符 的 转 义 序列 (IL 
32-1), 


表 2-1 和 转 义 字符 


























Š — 含 X 序 zl * X 
in 换行 \$ 美元 符号 
Ww 回 车 yx 双 引 号 
M 水 平 制 表 符 VOnnn 此 正则 表达 式 序列 匹配 一 个 用 八进制 表示 的 字符 
M 反 斜 线 字 符 \xnn 此 正则 表达 式 序列 匹配 一 个 用 十 六 进 制 表示 的 字符 


如 果 试 图 转 义 任何 其 他 字符 ， 反 斜 线 本 身 也 会 被 显示 出 来 。 双 引号 字符 串 最 重要 的 一 点 
是 能 够 解析 其 中 的 变量 。 
3) 定 界 符 。 男 一 种 给 字符 串 定 界 的 方法 是 使 用 定 界 符 语法 ( <<< ) 。 应 该 在 <<< 之 后 提 
供 一 个 标识 符 ， 接 着 是 字符 串 ， 然 后 是 同样 的 标识 符 结束 字符 串 。 例 如 : 
<? php 
// 输 出 为 :Hello World 


echo ««« abc 
Hello World 





abe; 
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在 此 段 代码 中 ， 标 识 符 命名 为 abc。 结 束 标识 符 必须 从 行 的 第 一 列 开 始 。 标 识 符 所 遵循 
的 命名 规则 是 只 能 包含 字母 数字 下 夯 线 ， 而 且 必须 以 下 夯 线 或 非 数 字 字 符 开始 。 

定 界 符 文本 表现 的 就 和 双 引 号 字符 串 一 样 ， 只 是 没有 双 引 号 。 这 半 味 着 在 定 界 符 文本 中 
不 需要 转 义 引号 ， 不 过 仍然 可 以 用 以 上 列 出 的 转 义 代码 ， 变 量 也 会 被 解析 。 在 以 上 的 3 种 定 
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中 的 变量 会 被 解析 。 





义 字 符 串 的 方法 中 ， 若 使 用 双 引 号 或 者 定 界 符 定义 字符 串 ， 
5. 数组 array 
PHP 中 的 数组 实际 上 是 一 个 有 序 图 ， 图 是 一 种 把 value 映射 到 key 的 类 型 。 新 建 一 个 数 
组 使 用 array( ) 语 言 结 构 ， 它 接受 一 定数 量 用 逗号 分 隔 的 key = > value 参数 对 。 
语法 如 下 : 


N 


array([ key = > ] value,...) 


HB, WE key 可 以 是 整 型 或 者 字符 串 ， 值 value 可 以 是 任何 类 型 ， 如 果 值 又 是 一 个 数组 ， 
则 可 以 形成 多 维 数组 的 数据 结构 。 例 如 : 














<? php 
$edName = array(0 = » "id" ,1 = > "username" ,2 = >" password" ) ; 
echo " 列 名 是 $edName[ 0] , $edName[ 1], $edName[2]" ; 
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此 段 代 码 的 输出 为 : 列 名 是 id, username, password, 
如 果 省 略 了 键 key， 会 自动 产生 从 0 开始 的 整数 索引 。 上 面 的 代码 可 以 改写 为 : 








<? php 


$edName = array( " id" , "username" ," password" ) ; 


echo " 列 名 是 $edName[ 0] , $edName[ 1], $edName[2]" ; 


? > 
此 段 代码 的 输出 仍 为 : 列 名 是 id、username password, 
如 果 key 是 整数 ， 则 下 一 个 产生 的 key 将 是 目前 最 大 的 整数 索引 加 1。 如 果 指 定 的 键 已 
经 有 了 值 ， 则 新 值 会 覆盖 旧 值 。 再 次 改写 上 面 的 代码 为 ; 





<? php 


$edName = array(1 = > "id" ," username" ," password" ) ; 


echo " 列 名 是 $edName| 1] , $edName[2] , $edName[3]" ; 
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此 段 代 码 的 输出 仍 为 : 列 名 是 id, username, password, 

定义 数组 的 另 一 种 方法 是 使 用 方 括号 的 语法 ， 通 过 在 方 括号 内 指定 键 为 数组 赋值 来 实 
现 。 也 可 以 省 略 键 ， 在 这 种 情况 下 给 变量 名 加 上 一 对 空 的 方 括号 (L1). 

语法 如 下 














$arrayName[ key ] = value; 


$arrayName [ | = value; 


其 中 ， 键 key 可 以 是 整 型 或 者 字符 串 ， 值 value 可 以 是 任何 类 型 。 例 如 : 





<? php 
$edName[0] = "id"; 
$edName| 1 | = " username" ; 


$edName| 2 ] = " password" ; 
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echo " 列 名 是 $edName[0] , $edName[ 1], $edName[2]" ; 
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此 段 代 码 的 输出 仍 为 : 列 名 是 id, username, password, 

如 果 给 出 方 括号 但 没有 指定 键 ， 则 取 当 前 最 大 整数 索引 值 ， 新 的 键 将 是 该 值 加 1。 如 果 > 
当前 还 没有 整数 索引 ， 则 键 将 为 0。 如 果 指 定 的 键 已 经 有 值 了 ， 该 值 将 被 覆盖 。 

对 于 任何 的 类 型 一 一 布尔 、 整 型 、 浮 点 、 字 符 串 和 资源 ， 如 果 将 一 个 值 转换 为 数组 ， 将 
得 到 一 个 仅 有 一 个 元 素 的 数组 (其 下 标 为 0) ， 该 元 素 即 为 此 标量 的 值 。 如 果 将 一 个 对 象 转 
换 成 一 个 数组 ， 所 得 到 的 数组 的 元 素 为 该 对 象 的 属性 (成员 变 量 )， 其 键 为 成 员 变 量 名 。 如 
果 将 一 个 NULL 值 转换 成 数组 ， 将 得 到 一 个 空 数组 。 

6. 对象 object 

使 用 class 定义 一 个 类 ， 然 后 使 用 new 类 名 (构造 函数 参数 ) 来 初始 化 类 的 对 象 。 该 数 
据 类 型 将 在 后 面 的 实例 中 具体 应 用 进行 解析 。 

7. 其 他 数据 类 型 

除了 以 上 介绍 的 6 种 数据 类 型 ， 还 有 资源 和 NULL 两 种 特殊 类 型 ， 下 面 简单 介绍 一 下 这 
两 种 特殊 类 型 。 

1) 资源 。 资 源 是 通过 专门 函数 来 建立 和 使 用 的 一 个 特殊 变量 ， 保 存 了 外 部 资源 的 一 个 
引用 。 可 以 保存 打开 文件 、 数 据 库 连 接 、 图 形 画布 区 域 等 的 特殊 句柄 ， 无 法 将 其 他 类 型 的 值 
转换 为 资源 。 资 源 大 部 分 可 以 被 系统 自动 回收 。 

2) NULL, NULL 类 型 只 有 一 个 值 ， 就 是 区 分 大 小 写 的 关键 字 NULL。 特 殊 的 NULL 值 表 
示 一 个 变量 没有 值 。 

在 下 列 情况 下 ， 一 个 变量 被 认为 是 NULL, 

e 被 赋值 为 NULL, 

e. 尚未 被 赋值 。 

e 被 unset( ) o 

例如 : 












































<? php 

Sphpz^"; 

if( isset( $a) ) 

echo^[1] is NULL <br>”; 
$php 20; 

if( isset( $a) ) 

echo* [2] is NULL <br>”; 
$php = NUI; 

if( isset( $a) ) 

echo* [3] is NULL <br>”; 
$php = FALSE; 

if( isset( $a) ) 

echo^[4] is NULL <br>”; 


To 












QL*Dreamweaver 动态 网 站 开发 从 入 门 到 精通 





结果 是 什么 ? 

在 3 种 情况 下 ， 变 量 被 认为 是 空 值 。 

1) 变量 没有 被 赋值 。 

2) 变量 被 赋值 为 NULL，0 ，False 或 者 空 字 符 串 。 
3) 变量 在 非 空 值 的 情况 下 ， 被 unset 函数 释放 。 


DS 数据 类 型 转换 


在 PHP 中 若 要 进行 数据 类 型 的 转换 ， 就 要 在 转换 的 变量 之 前 加 上 用 括号 括 起 来 的 目标 
类 型 。 在 变量 定义 中 不 需要 显 式 的 类 型 定义 ， 变 量 类 型 是 根据 使 用 该 变量 的 上 下 文 所 决 























D 
定 的 。 
例如 ， 通 过 类 型 的 转换 ， 可 将 变量 或 其 所 附带 的 值 转换 成 另外 一 种 类 型 ， 如 图 2-18 
所 示 。 
<? php 
$num = 123; // 当 前 是 整数 类 型 
$float = (float) $num; 
// $num“ 临 时 性 ”地 转换 成 了 浮 点 型 ,$float 变量 所 携带 的 数据 类 型 就 为 浮 点 型 
echo gettype( $num)." <br/>"; // 使 用 gettype( mixed var) 函数 来 获取 变量 类 型 
echo gettype( $float) 
?> 
A PHP 变 量 类 型 转换 — Nicrosoft Internet Explorer BAE 
WFO REO 查看 WW) REN IAM $500 a 
QmB- ©- DAGER ux O6 | 四- SBL 
地 址 0) &] http://127.0.0. l/php/PHP/PHP var type change. php w ges 链接 Q SnagIt Ej 
?php 
$num - 123; 
$float = (float) $num; 
echo g ($num). "<br />" :// 使 用 gettype (mixed var) 团 数 来 获取 变量 类 型 
echo gettype($float) 
输出 结果 
integer 
double 
和 Internet 
图 2-18 数据 类 型 的 转换 
提示 : 


如 要 将 一 变量 彻底 转换 成 另 一 种 类 型 ， 就 要 使 用 settype (mixed var, string type) 函数 。 
允许 的 强制 转换 有 如 下 几 种 。 
1) int, integer; 转换 成 整 型 。 
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2) bool, boolean: 转换 成 布尔 型 。 

3) float, double, real: 转换 成 浮 点 型 。 
4) string: 转换 成 字符 串 。 

5) array: 转换 成 数组 。 

6) object: 转换 成 对 象 。 


PHP 中 的 运算 符 


对 于 学 过 其 他 语言 的 读者 ， 运 算 符 应 该 不 会 陌生 了 。 运 算 符 可 以 用 来 处 理 数 字 、 字 符 串 
及 其 他 比较 运算 和 人 逻辑 运算 等 。 在 PHP 中 ,运算 符 两 侧 的 操作 数 会 自动 地 进行 类 型 转换 ， 
这 在 其 他 的 编程 语言 中 并 不 多 见 。 在 PHP 的 编程 中 主要 有 以 下 3 种 类 型 的 运算 符 。 

1) 一 元 运算 符 。 只 运算 一 个 值 ， 例 如 :! ( 取 反 运算 符 ) 或 ++ (加 一 运算 符 )。 

2) 二 元 运算 符 。PHP 支持 的 大 多 数 运算 符 都 是 这 种 ， 例 如 : $a+ $b, 

3) 三 元 运算 符 。 即 ?， 它 被 用 来 根据 一 个 表达 式 在 另 两 个 表达 式 中 选择 一 个 ， 而 不 是 用 
来 在 两 个 语句 或 者 程序 路 线 中 选择 。 

PHP 中 常用 运算 符 有 算术 运算 符 、 赋 值 运 算 符 、 比 较 运算 符 、 三 元 运算 符 、 错 误 控 制 
运算 符 、 逻 辑 运 算 符 、 字 符 串 运 算 符 、 数 组 运算 符 等 。 本 节 就 主要 介绍 常用 的 运算 符 ， 以 及 
运算 符 的 优先 级 。 


NOB 算术 运算 符 


算术 运算 符 是 用 来 处 理 四 则 运算 的 符号 ， 是 最 简单 、 也 最 常用 的 符号 ， 尤 其 是 数字 的 
理 ， 几 乎 都 会 使 用 到 算术 运算 符号 。PHP 的 算术 运算 符 如 表 2-2 所 示 。 
表 2-2 算术 运算 符 














E 














TF 号 7R 例 名 称 意 义 
一 - $a 取 反 $a 的 负 值 
十 $a4 $b 加 法 $a 和 $b 的 和 
一 $a- $b 减法 $a 和 $b 的 差 
* $a * $b 乘法 $a 和 $b 的 积 
/ $a/ $b 除法 $a 除 以 $b 的 商 
% $a % $b 余数 $a 除 以 $b 的 余数 
十 十 $a44 累加 $a 的 累加 
-- $a-- 递减 $a 的 递减 


TE, RS (/) 总 是 返回 浮 点 数 ， 即 使 两 个 运算 数 是 整数 (或 由 字符 串 转 换 成 的 整 
数 ) 也 是 这 样 。 


PAPE 赋值 运算 符 


赋值 运算 符 (Assignment Operator) 把 表达 式 右边 的 值 赋 给 左边 的 变量 或 常量 。 基 本 的 
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赋值 运算 符 是 = ， 它 意味 着 把 右边 表达 式 的 值 赋 给 左边 的 运算 数 。PHP 中 的 赋值 运算 符 如 








表 2-3 所 示 。 
表 2-3 赋值 运算 符 

符 号 示 dl 意 X 
- $a=$b 将 右边 的 值 连 到 左边 
+= $a += $b 将 右边 的 值 加 到 左边 ， 即 $a = $a + $b 
-- $a -= $b 将 右边 的 值 减 到 左边 ， 即 $a =$a - $b 
* 二 $a* =$b 将 左边 的 值 乘 以 右边 ， 即 $a = $a* $b 
ja $a/=$b 将 左边 的 值 除 以 右边 ， 即 $a-$a/$b 
% = $a% $b 将 左边 的 值 除 对 右边 取 余 数 ， 即 $a = $a% $b 
m $a. 2$b 将 右边 的 字 串 加 到 左边 ， 即 $a = $a. $b 

















在 基本 赋值 运算 符 之 外 ， 还 有 适合 于 所 有 二 元 算术 和 字符 串 运 算 符 的 “组 合 运算 符 ”， 
这 样 可 以 在 一 个 表达 式 中 使 用 它 的 值 并 把 表达 式 的 结果 赋 给 它 ， 例 如 : 
<? php 
$a =" baidu" ; 
$b=". com"; 
echo $a. = $b; 
7» 


运行 结果 如 图 2-19 所 示 。 


E] RIET 一 Nicrosoft Internet Explorer 
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$a -"baidu"; 
$b =". com"; 
echo $a .= $b; 


输出 结果 


baidu.com 








图 2-19 赋值 运算 字符 串 结果 


和 县 甬 | 比较 运算 符 


比较 操作 符 ， 顾 名 思 义 就 是 可 用 来 比较 的 操作 符号 ， 根 据 结果 来 返回 True 或 False。 比 
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较 运算 符 ， 允 许 对 两 个 值 进行 比较 ，PHP 的 比较 运算 符 如 表 2-4 所 示 。 
表 2-4 比较 运算 符 
示 ü 名 K 意 X 
$a == $b 等 于 True， 如 果 $a 等 于 $b 
$a === $b 全 等 True, WR $a 等 于 $b， 并 且 它 们 的 类 型 也 相同 
$a! = $b 不 恒 冬 True， 如 果 $a 不 恒 等 于 $b 
$a< > $b 不 等 True， 如 果 $a 不 等 于 $b 
$a! == $b 非 全 等 True, WR $a 不 等 于 $b， 或 者 它们 的 类 型 不 同 (PHP 4 引进 ) 
$a« $b 小 于 True, WR $a 严格 小 于 $b 
$a > $b RF True， 如 果 $a 严格 大 于 $b 
$a <= $b 小 于 等 于 True, W $a 小 于 或 者 等 于 $b 
$a >= $b 大 于 等 于 True， 如 果 $a 大 于 或 者 等 于 $b 

















WE 三 元 运算 符 
元 运算 符 是 ?: ， 三 元 运算 符 的 功能 和 if...else 语句 很 相似 ， 语 法 如 下 : 
(exprl )? (expr2 ) : ( expr3) 
首先 对 exprl 求 值 ， 若 结果 为 True， 则 表达 式 (exprl)? (expr2 ) : (expr3 ) 的 值 为 expi2, 
否则 其 值 为 exprz3 。 例 如 
<? php 
$action = (empty( $. POST[ action ]))? default : $_POST[ action ]; 
7» 
首先 判断 $ POST[ action ] 变 量 是 否 为 空 值 ， 若 是 ， 则 给 $action WEW default, BU 
将 $_POST[ actin ] 变 量 的 值 赋值 给 $action。 可 以 将 上 面 的 代码 改写 成 以 下 的 代码 : 
<? php 


if(empty( $. POST[ action ] ) )| 


$action = default ; 





| else | 
$action = $_POST] action ]; 
| 


7» 


2. 6. 5 B xIS miS 


错误 控制 操作 符 (@ ) 可 在 任何 表达 式 前 使 用 ，PHP 支持 一 个 错误 控制 运算 符 @ 。 当 
将 其 放置 在 一 个 PHP 表达 式 之 前 ， 该 表达 式 可 能 产生 的 任何 错误 信息 都 被 忽略 掉 。@ 运算 
符 只 对 表达 式 有 效 。 

那么 ， 何 时 使 用 此 运算 符 呢 ? 一 个 简单 的 规则 就 是 ， 如 果 能 从 某 处 得 到 值 ， 就 能 在 它 前 
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TU beisTEkM, n, nIEAJETEHOCEAERE. KA include( ) 调 用 、 常 量 等 之 前 。 不 能 
它 放 在 函数 或 类 的 定义 之 前 ， 也 不 能 用 于 条 件 结构 ， 例 如 让 和 foreach 等 。 
对 于 如 下 的 代码 : 


<? php 

$ Conn = mysql. connect( " localhost" ," username" ," pwd" ) ; 
if( $ Conn) 

echo "连接 成 功 !" ; 
else 


echo "连接 失败 !" ; 
T 


如 果 mysql. connect ( ) 连接 失败 ， 将 显示 系统 的 错误 提示 ， 而 后 继续 执行 下 面 的 程序 。 
如 果 不 想 显 示 系 统 的 错误 提示 ， 并 希望 失败 后 立即 结束 程序 ， 则 可 以 改写 上 面 的 代码 如 下 : 





<? php 
$ Conn = € mysql. connect( " localhost" ," username" ," pwd" ) or die(" 连 接 数据 库 服务 器 出 错 " ) ; 
?> 
在 mysql_connect( ) 函数 前 加 上 @ 运 算 符 来 屏蔽 系统 的 错误 提示 ， 同 时 使 用 die( ) 函数 给 
出 自 定 义 的 错误 提示 ， 然 后 立即 退出 程序 。 这 种 用 法 在 大 型 程序 中 很 常见 。 


"cg 逻辑 运算 符 
PHP 的 逻辑 运算 符 (Logical Operators) 通常 用 来 测试 真 假 值 ， 常 用 的 逻辑 运算 符 如 


表 2-5 所 示 。 
表 2-5 逻辑 运算 符 








名 称 DS 例 意 X 
and $a and $b 如 果 $a 与 $b 都 为 True 
or $a or $b 如 果 $a 2X $b 任 一 为 True 
xor $a xor $b 如 果 $a sk $b 任 一 为 Tue， 但 不 同时 是 
not ! $a 如 果 $a 不 为 True 
and $a && $b 如 果 $a 与 $b 都 为 True 
or $a || $b 如 果 $a 或 $b 任 一 为 True 








“与 ”和 “或 ”有 两 种 不 同形 式 运算 符 ， 它 们 运算 的 优先 级 不 同 ，&& 和 | 优先 级 高 。 


2 字符 串 运 算 符 


字符 串 运 算 符 (String Operator) 有 两 个 字符 串 运算 符 。 第 一 个 是 连接 运算 符 (. ) ， 它 
返回 其 左右 参数 连接 后 的 字符 串 。 第 二 个 是 连接 赋值 运算 符 C = ) ， 它 将 右边 参数 附加 到 
左边 的 参数 后 面 。 

例如 : 
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<? php 
$a =" 你 好 " ; 
$a = $a. "MÆ!" ;// 此 时 $a 是 "你 好 朋友 1" 
$b =" 你 好 "; 
$b . =" 朋 友 !1"; /此 时 $b 是 "你 好 朋友 1 
T 





NOE 数组 运算 符 


PHP 的 数组 运算 符 ， 如 表 2-6 所 示 。 
表 2-6 数组 运算 符 























符 号 m 例 意 X 
+ $a+ $b $a 和 $b 的 联合 ， 返 回 包含 了 $a 和 $b 中 所 有 元 素 的 数组 
= $a== $b 如 果 $a 和 $b 具有 相同 的 元 素 ， 就 返回 True 
zzz $a === $b 两 者 具有 相同 元 素 且 顺序 相同 ， 返 回 True 
hz $a! = $b 如 果 $a 和 $b 不 是 等 价 的 ， 就 返回 True 
< > $a< > $b 如 果 $a 不 等 于 $b， 就 返回 True 
[=s $a! == $b 如 果 $a 和 $b 不 是 恒 等 的 ， 就 返回 True 


联合 运算 符 〈 + ) 把 右边 的 数组 附加 到 左边 的 数组 后 面 ， 但 是 重复 的 键 值 不 会 被 覆盖 。 
下 面 通 过 一 个 实例 来 看 一 下 如 何 用 + 运算 符 联 合 两 个 数组 : 


<? php 

$a=array("1" = >"Nol", 
"2" 2 »"No2", 

"3"- »"No3", 

"4" = »2"No4"); 


$b =array( "3" = »"No3", 


"4" = > "No4", 
"5" = > "No5", 
"6" = >"No6"); 
$c= $a+ $b; 


print r( $c); /联合 两 数组 
echo " <br/>"; 

if( $a== $b) 

echo "等 价 " ; 

else 

echo " 不 等 价 " ; 


7» 


可 以 看 到 ， 在 联合 之 后 的 数组 结果 如 图 2-20 所 示 。 
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"5"z»"No5", 
"6"-»"No6"); 
$c = $a*fb; 
print_r($c) ; /i 联合 两 数组 
echo “<br /5"; 
if ($a--$b) 
echo "SEffp": 
else 


echo“ 不 等 价 “; 


输出 结果 
Array ([1] => No1 [2] => No2 [3] => No3 [4] => No4 [5] => No5 [B] => No6 ) 
不 等 价 





Ø Internet 





图 2-20 联合 数组 示例 


Jo 运算 符 的 优先 级 


运算 符 优先 级 指定 了 两 个 表达 式 绑 定 得 有 多 “紧密 ”。 例 如 ， 表 达 式 1 +2 *3 的 结果 是 
7 而 不 是 9 是 因为 乘 号 (* ) 的 优先 级 比 加 号 ( + ) 高 。 必 要 时 可 以 用 括号 来 强制 改变 优 
先 级 ， 例 如 (1 +2) * 3 的 值 为 9。 使 用 括号 也 可 以 增强 代码 的 可 读 性 。 如 果 运 算 符 优先 级 
相同 ， 则 使 用 从 左 到 右 的 左 结合 顺序 ( 左 结 合 表示 表达 式 从 左 向 右 求 值 ， 右 结合 相反 )。 

表 2-7 从 高 到 低 列 出 了 PHP 所 有 运算 符 的 优先 级 。 同 一 行 中 的 运算 符 具有 相同 优先 级 ， 
此 时 它们 的 结合 方向 决定 求 值 顺序 。 


表 2-7 运算 符 优先 级 
































结合 方向 is 算 T 附加 信息 
非 结合 new new 
[ array( ) 
非 结合 ++ 一 一 递增 /递减 运算 符 
非 结 合 |! ~ — (int) ( float) ( string) ( array) ( object) @ 类 型 
左 * / % 算数 运算 符 
左 FS 算数 运算 符 和 字符 串 运算 符 
左 < > 位 运算 符 
非 结合 << >= 比较 运算 符 
非 结合 = 比较 运算 符 
左 & 位 运算 符 和 引用 
左 | 位 运算 符 
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ER. snl SIL PHP 编 程 基 础 
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附加 信息 
&& 逻辑 运算 符 
| 逻辑 运算 符 
Ta 三 元 运算 符 
. =% =&=1= = «= >= 赋值 运算 符 
and 逻辑 运算 符 
xor 逻辑 运算 符 
or 逻辑 运算 符 

多 处 用 到 
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将 结合 前 面 所 用 到 的 操作 符号 来 完成 一 项 需要 综合 使 用 它们 的 任务 ,如 图 2-21 所 示 。 


<? php 

// 定 义 几 个 常量 ,最 好 是 使 用 大 写 

define( " PEN" ,20) ; // AE y 20 元 
define( " RULE" ,10) ; // RF 10 元 
$pen. num = 10; //10 只 钢笔 
$ruler_num =20; //20 把 尺子 


$total_price = $pen num * PEN 
+ $ruler num * RULE; 


$total_price = number format( $total_price) ; 


echo " 购买 10 只 钢笔 和 20 把 尺子 一 共 要 花 ". $total_price. "JÙ"; 
To 
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define("RULE", 10); // 尺 子 为 10 元 


$pen num = 10; //10H385& 


$ruler num 220; //2018 RF 


$total price = $pen num * PEN 


+ $ruler num * RULE; 
$total price = number format($total price); 


echo“ 购 买 10 只 钢笔 和 20 把 尺子 一 共 要 花 ". $total price." X5": 


?> 


输出 结果 
购买 10 只 袍 笔 和 20 把 尺子 一 共 要 花 400 元 








图 2-21 综合 运算 符 的 应 用 示例 
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PHP 的 表达 式 


在 PHP 程序 中 ， 任 何 一 个 可 以 返回 值 的 语句 ， 都 可 以 看 做 表达 式 。 也 就 是 说 ， 表 达 式 
是 一 个 短语 ， 能 够 执行 一 个 动作 ， 并 具有 返回 值 。 一 个 表达 式 通常 由 两 部 分 构成 ， 一 部 分 是 
操作 数 ， 另 一 部 分 是 运算 符 。 本 节 介 绍 常 用 的 几 种 控制 语句 表达 式 ， 分 别 是 条 件 语 句 、 循 环 
语句 ， 以 及 require 和 include 语句 等 其 他 语句 。 


条 件 语句 在 PHP 中 非常 普遍 ， 是 PHP 程序 的 主要 控制 语句 之 一 。 通 常情 况 下 ， 在 客户 
端 获 得 一 个 参数 ， 根 据 传人 的 参数 值 ， 做 出 不 同 的 响应 。 在 PHP 中 条 件 语句 分 别 为 让 语句、 
if — else 语句 、if — elseif — else 语句 和 switch 语句 。 

下 面 我 们 分 别 介绍 这 4 种 形式 的 条 件 语句 : 

1. 证 语句 

计 语 句 是 许多 高 级 语言 中 重要 的 控制 语句 ， 使 用 站 语句 可 以 按照 条 件 判断 来 执行 语句 ， 
增强 了 程序 的 可 控制 性 。 只 有 六 语句 的 条 件 语句 是 最 简单 的 一 种 条 件 语句 ， 语 法 如 下 : 














if( expr) 
statement 
首先 对 expr 求 值 ， 如 果 expr 的 值 为 True， 则 执行 statement; 如 果 值 为 False， 将 忽略 
statement , 


图 2-22 所 示 为 上 述 语法 格式 在 执行 时 的 逻辑 结构 。 





False ( 假 ) 











图 2-22 半 语 句 逻 辑 示意 图 











例如 : 


<? php 
$Numl =10; 
$Num2 =9; 
if( $Numl > $Num2) 
echo " $Numl 大 于 $Num2" ; 


7» 


上 述 实例 演示 了 半 语 句 的 使 用 ， 会 在 变量 $ Numl 大 于 $Num2 时 ， 输 出 “$ Numl 大 于 
$Num2", 
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2. if -— else 语句 
条 件 语 句 的 第 2 种 形式 是 让 - else， 除 了 让 语句 之 外 ， 还 加 上 了 else 语句 ， 它 可 以 在 六 
语句 中 的 表达 式 的 值 为 False 时 执行 ， 语 法 如 下 : 


if( expr) 


e 





statement] 
else 


statement2 


首先 ， 对 expr 求 值 ， 如 果 expr 的 值 为 True， 则 执行 statement ; 如 果 值 为 False ， 则 执行 
statement2 。 例 如 ， 以 下 代码 在 $a 大 于 $b 时， 显示 a 大 于 b; RZ, 则 显示 a 不 大 于 b。 
这 种 情况 的 执行 逻辑 结构 如 图 2-23 所 示 。 











图 2-23 if-else 语句 逻辑 示意 图 
例如 ， 以 下 代码 在 Sa 大 于 $b 时 ， 显 示 a 大 于 b; RZ, WER a ACT b. 














<? php 
if( $a > $b) 
echo "a KF b"; 
else 


echo "a 不 大 于 b" ; 
? > 

注意 : 

else 语句 仅 在 这 以 及 elseif (如 果 有 的 话 ) 语句 中 的 表达 式 的 值 为 False 时 执行 ， 它 不 可 
以 单独 使 用 。 

3. if — elseif — else 语句 

条 件 语句 的 第 3 种 形式 是 让 - elseif - else, elseif 是 让 和 else 的 组 合 。 和 else 一 样 ， 它 延 
伸 了 并 语句 ， 可 以 在 原来 的 计 表 达 式 值 为 False 时 执行 不 同 语句 。 但 是 和 else 不 一 样 的 是 ， 
它 仅 在 elseif 的 条 件 表 达 式 值 为 True 时 执行 语句 ， 语 法 如 下 : 


if( expl) 
statementl 

elseif( exp2 ) 
statement2 


elseif( exp3 ) 


else 


statementn 
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首先 ， 对 exprl 求 值 ， 如 果 exprl 的 值 为 True， 则 执行 statementl ， 如 果 值 为 False， 则 对 
expr2 求 值 ， 如 果 expr2 的 值 为 Tue， 则 执行 statement2; 如 果 值 为 False ， 则 对 expr3 求 值 ， 
依次 类 推 ， 如 果 所 有 的 表达 式 的 值 都 为 False ， 则 执行 statementn, 

这 种 情况 的 执行 逻辑 结构 如 图 2-24 所 示 。 





True (X) 











程序 片段 3 


图 2-24 if- elseif — else 语句 逻辑 示意 图 








例如 ， 以 下 代码 将 根据 条 件 分 别 显 示 a CT b, a 等 于 b 和 a 小 于 b: 











<? php 
if( $a > $b)| 
echo "a KF b"; 
| elseif( $a== $b)| 
echo "a 等 于 b" ; 
| else | 


echo "a 小 于 b"; 
} 
?> 
注意 : 
elseif 也 可 以 写成 else if (两 个 单词 )， 它 和 elseif (一 个 单词 ) 的 行为 完全 一 样 。 
4. switch 语句 
使 用 switch 语句 可 以 避免 大 量 地 使 用 if-else 控制 语句 。switch 语句 首先 根据 变量 值得 
到 一 个 表达 式 的 值 ， 然 后 根据 表达 式 的 值 执行 语句 。switch 语句 计算 expression 的 值 ， 然 
后 和 case 后 的 值 进行 比较 ， 跳 转 到 第 一 个 匹配 的 case 语句 开始 执行 后 面 的 语句 ， 如 果 没 
有 case 匹配 就 跳 转 到 default 语句 执行 ， 如 果 没 有 default 语句 ， 则 退出 。 当 找到 匹配 项 的 时 
候 ， 解 析 器 会 一 直 运 行 ， 直 到 switch 结尾 或 者 遇见 break 语句 为 止 。case 语句 可 以 使 用 空 
语句 。 


PHP EHETI (switch) 语句 来 直接 处 理 多 分 文选 择 ， 语 法 如 下 : 














switch( expr) | 


case constant — expression ; 
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statement 

jump — statement 
[ default; 

statement 


e 


jump - statement 
] 
| 


其 中 的 常量 表达 式 (constant - expression). 可 以 是 任何 求 值 为 简单 类 型 的 表达 式 ， 即 整 
型 或 浮 点 数 以 及 字符 串 。 
其 逻辑 结构 如 图 2-25 所 示 。 














图 2-25 switch 语句 逻辑 结构 


下 面 一 段 代 码 是 switch 语句 的 简单 应 用 : 


<? php 
switch( $a) | 
case 0: 
echo "a 20" ; 
break; 
case 1; 
echo "a=1"; 
break; 
case 2: 
echo "a 22" ; 
break; 
| 


7» 


switch 语句 一 行 接 一 行 地 执行 〈 实 际 上 是 语句 接 语 句 ) y JF UID (FO EDU, DUU 
一 个 case 语句 中 的 值 和 switch 表达 式 的 值 匹 配 时 ，PHP 才 开 始 执行 语句 ， 直 到 switch 的 程 
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序 段 结束 或 者 遇 到 第 一 个 break 语句 为 止 。 如 果 不 在 case 的 语句 段 最 后 写 上 break 的 话 ， 
PHP 将 继续 执行 下 一 个 case 中 的 语句 段 。 例 如 : 
<? php 
switch( $a) | 
case 0; 
echo "a 20" ; 
case 1; 
echo "a=1"; 
case 2 : 
echo "a=2"; 


7» 
这 里 如 果 $a 等 于 0，PHP 将 执行 所 有 的 输出 语句 ; 如果 Sa 等 于 1，PHP 将 执行 后 面 两 
条 输出 语句 。 只 有 当 $a 等 于 2 时 ， 才 会 得 到 结果 : a =2。 


2.7.2 EEN 


循环 语句 也 称 为 迭代 语句 ， 让 程序 重复 执行 某 个 程序 块 ， 直 到 某 个 特定 的 条 件 表达 式 结 
果 为 假 时 ， 结 束 执行 语句 块 。 在 PHP 中 循环 语句 的 形式 有 : while 循环 、do - while 循环 、for 
循环 和 foreach 循环 。 

1. while 循环 语句 

while 语句 控制 语句 的 循环 执行 。 格 式 为 : 


while( expr) 
statement 
只 要 expr 的 值 为 True 就 重复 执行 谍 套 中 的 循环 语句 。 每 次 开始 循环 时 检查 expr 的 值 。 
有 时 如 果 while 表达 式 的 值 一 开始 就 是 False， 则 循环 语句 一 次 都 不 会 执行 。 一 般 来 说 ， 在 代 
码 片段 中 会 改变 表达 式 中 变量 的 值 ， 否 则 可 能 成 为 死 循 环 。 图 2-26 所 示 为 该 语句 的 逻辑 








2-26 while 语句 逻辑 示意 图 


例如 : 


<? php 
$a-1; 
while( $a <5) | 
echo $a 44; // 从 1~5 依次 输出 
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a 





?> 


执行 该 程序 后 会 输出 从 1 ~5 的 数字 。 
2. do - while 循环 语句 





do - while 语句 和 while 语句 基本 一 样 。 不 同 之 处 在 于 ，while 语句 在 “ | }” 内 的 语句 执 
行 之 前 检查 条 件 是 否 满足 ， 而 do- while 语句 则 先 执行 “ | }” 内 的 语句 ， 然 后 再 判断 条 件 是 
否 满 足 ， 如 果 满 足 就 继续 循环 ， 不 满足 就 跳出 循环 。 格 式 为 
do 
statement 
while( expr) 


图 2-27 所 示 为 该 语句 的 逻辑 结构 。 


Start True ( 真 ) End 
和 4 结 
程序 运行 程序 片段 «x vus quil ER 


图 2-27 do- while 语句 逻辑 示意 图 


例如 : 


<? php 
$a=0; 
do | 
echo $a; 


| 
while( $a »0); 


To 


以 上 循环 将 正好 运行 一 次 ， 因 为 经 过 第 一 次 循环 后 ， 当 检查 表达 式 的 真 值 时 ， 因 其 值 为 
False ( $a 不 大 于 0) 而 导致 循环 终止 。 

3. for 循环 语句 

for 循环 是 PHP 中 最 复杂 的 循环 结构 。for 循环 的 语法 是 : 


for( exprl ; expr2 ;expr3 ) 


statement 


其 中 ,第 1 个 exprl 在 循环 开始 前 无 条 件 求 值 一 次 。 第 2 个 expr 在 每 次 循环 开始 前 求 
值 ， 如 果 值 为 Tue， 则 继续 循环 ， 执 行人 套 的 循环 语句 ; 如 果 值 为 False， 则 终止 循环 。 第 3 
个 expr3 在 每 次 循环 之 后 被 求 值 (执行 ) 。 每 个 表达 式 都 可 以 为 空 。expr2 为 空 意味 着 将 无 限 
循环 下 去 (和 C 一样 ，PHP 认为 其 值 为 True) ， 因 为 有 时 候 会 希望 用 break 语句 来 结束 循环 ， 
而 不 是 用 for 的 表达 式 真 值 判 断 。 

图 2-28 所 示 为 该 语句 的 逻辑 结构 ， 表 达 式 2 为 True 则 执行 程序 片段 ， 其 值 在 表达 式 1 
中 初始 化 ， 在 表达 式 3 中 进行 修改 。 
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图 2-28 for 语句 逻辑 示意 网 





下 面 通过 使 用 for 循环 语句 输出 九 九 乘法 表 ; 
<? php 
for( $121; $1 «10; $i++) 
| 

for( $j21; $j «10; $j 44) 

| 
echo " $1* $j=". $i* $j; 
echo " &nbsp" ; 

Í 

echo " <br/>"; 


| 
7» 
4. foreach 循环 语句 
foreach 语句 是 一 种 用 来 遍历 数组 中 数据 的 简便 方法 。foreach 仅 能 用 于 数组 ， 当 试图 将 
其 用 于 其 他 数据 类 型 或 者 一 个 未 初始 化 的 变量 时 会 产生 错误 。foreach 语句 有 两 种 语法 ,第 2 
种 比较 次 要 ， 但 却 是 第 1 种 的 有 用 的 扩展 。 
第 1 种 语法 : 
foreach( array_expression as $value) 


statement 
第 2 种 语法 : 
foreach( array_expression as $key = > $value) 
statement 
第 1 种 语法 格式 遍历 给 定 的 array_expression 数组 。 每 次 循环 中 ， 当 前 单元 的 值 被 赋 给 
$value， 并 且 数 组 内 部 的 指针 向 前 移 一 步 〈 因 此 下 一 次 循环 中 将 会 得 到 下 一 个 单元 ) 。 第 2 
种 格式 做 同样 的 事 ， 只 除了 当前 单元 的 键 名 也 会 在 每 次 循环 中 被 赋 给 变量 $key。 其 执行 的 
逻辑 结构 如 图 2-29 所 示 。 











False ( 假 ) 





2-29 foreach 语句 逻辑 示意 图 
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该 语句 的 使 用 方法 如 下 : 
<? php 
$arr = array("one" ," two" ," three" ) ; 
foreach( $arr as $value) | 


echo " Value; $value « br / > n" ; 





| 


7» 
此 段 代码 的 输出 为 : 


Value: one 
Value: two 


Value: three 


在 这 段 代码 中 遍历 数组 使 用 的 是 foreach 语句 的 第 1 种 格式 ， 也 可 以 使 用 第 2 种 格式 。 
改写 上 面 的 代码 如 下 : 


<? php 
$arr = array("one" ," two" ," three" ) ; 
foreach( $arr as $key = > $value) | 
echo "Key: $key;Value; $value «br / > 3n"; 
PU 


此 段 代 码 的 输出 为 : 


Key: 0;Value: one 
Key: 1;Value: two 
Key: 2; Value: three 


2.7.3 


为 了 帮助 程序 员 更 加 精确 地 控制 整个 流程 ， 方 便 程序 的 设计 ，PHP 还 提供 了 一 些 其 他 
语句 ， 这 里 做 一 下 简单 的 介绍 。 

1) break 语句 。break 语句 用 来 结束 当前 的 for, while 或 switch 循环 结构 ， 继 续 执行 下 面 
的 语句 。break 语句 后 面 可 以 跟 一 个 数字 ， 用 于 在 构 套 的 控制 结构 中 表示 跳出 控制 结构 的 
层 数 。 

2) continue 语句 。continue 语句 用 来 跳出 循环 体 ， 不 继续 执行 循环 体 下 面 的 语句 ， 而 是 
回 到 循环 判断 表达 式 ， 并 决定 是 否 继续 执行 循环 体 。continue 语句 后 面 同样 可 以 跟 一 个 数 
字 ， 其 作用 和 break 语句 相同 。 

3) return 语句 。return( ) 语 句 通 常用 于 函数 中 ， 如 果 在 一 个 函数 中 调用 retum ( ) 语句 ， 
将 立即 结束 此 函数 的 执行 并 将 它 的 参数 作为 函数 的 值 返回 。 

4) include( ) 语 句 和 require( ) 语 句 。 包 含 并 运行 指定 文件 。require( ) 和 include( ) 除 了 处 
理 失 败 之 外 ， 在 其 他 方面 都 完全 一 样 。include( ) 产生 一 个 警告 ， 而 require( ) 则 导致 一 个 至 
命 错误 。 也 就 是 说 ， 如 果 想 在 丢失 文件 时 停止 处 理 页 面 ， 应 该 使 用 require( ) ， 而 include( ) W 
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会 继续 执行 脚本 ， 同 时 也 要 确认 设置 了 合适 的 include_path。 

5) require_once( ) 语 句 和 include, once( ) i^], require, once( ) 语 句 和 include_once( ) 语 
句 分别 对 应 require ( ) AJJI include( ) 语 句 。require_once( ) 语句 和 include, once ( ) 语 句 主 要 
用 于 需要 包含 多 个 文件 时 ， 可 以 有 效 地 避免 把 同一 段 代码 包含 进去 而 出 现 函 数 或 变量 重复 定 
义 的 错误 。 


PHP 的 函数 


程序 在 完成 一 个 功能 时 ， 可 以 把 众多 的 程序 写 在 一 起 ， 但 这 样 容易 引起 混乱 。 另 一 种 策 
略 就 是 把 总 的 功能 分 成 小 的 功能 模块 ， 把 每 一 个 模块 分 别 实现 ， 在 总 的 框架 中 根据 需要 把 模 
块 搭建 在 一 起 。 实 现 程序 模块 化 的 策略 就 是 使 用 函数 ， 直 观 来 说 ， 函 数 就 是 代表 一 组 语句 的 
标识 符 ， 在 使 用 函数 时 ， 外 部 调用 者 不 需要 关心 函数 的 内 部 处 理 过 程 ， 只 需要 关心 函数 的 输 
入 和 输出 接口 的 应 用 。 函 数 可 以 简单 地 分 为 两 大 类 : 一 类 是 系统 函数 ， 一 类 是 用 户 自 定义 天 
数 。 对 于 系统 函数 ， 可 以 在 需要 时 直接 选择 使 用 ， 而 用 户 自 定义 函数 ， 首 先 要 定义 ， 然 后 才 
能 使 用 。 本 市 的 重点 是 如 何 定义 并 使 用 用 户 自 定义 函数 ， 主 要 包括 函数 定义 的 一 般 形 式 、 画 
数 的 参数 和 返回 值 、 函 数 的 诅 套 和 递归 等 。 


UL 8B 


一 个 函数 可 由 以 下 的 语法 来 定义 : 


function funeName([ $arg 1][ , $arg 2][,…]|, $arg_n])| 








statement 


| 
定义 函数 时 需要 使 用 function 关键 字 ， 之 后 是 函数 名 ， 有 效 的 函数 名 必须 以 字母 或 下 画 
线 打 头 ， 后 面 跟 字 母 、 数 字 或 下 画 线 。 $arg_1 到 $arg_n 为 函数 的 可 选 参数 列表 ， 不 同 的 参 
数 之 间 用 逗号 分 隔 。 在 函数 内 部 可 以 放置 任何 有 效 的 PHP 代码 ， 甚 至 包括 其 他 函数 和 类 
定义 。 
例如 : 








<? php 

function maxNum( $a, $b) | 
$c= $a» $b? $a: $b; 
return $c; 


| 
echo maxNum(10 ,100) ;// 输 出 :100 


?> 
上 面 的 一 段 代码 也 可 以 写成 


<? php 
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echo maxNum(10 ,100) ;// 输 出 :100 
function maxNum( $a, $b)! 

$c= $a» $b? $a: $b; 

return $c; 

| 


7» 





20D BUS 


通过 函数 参数 列表 可 以 传递 信息 到 函数 。PHP 支持 按 值 传递 参数 ， 通 过 引用 传递 以 及 
默认 参数 。 默 认 情 况 下 ， 函 数 参 数 通 过 值 传递 ， 即 车 在 函数 内 部 改变 了 参数 的 值 ， 也 不 会 影 
响 到 函数 外 部 的 值 。 

例如 : 


<? php 

function change( $string) | 
$string = "改变 之 后 " ; 

| 

$str = "改变 之 前 " ; 

change( $str) ; 

echo $str; 


7» 
这 段 代 码 的 输出 为 “改变 之 前 ” 。 尽 管 在 函数 内 部 改变 了 参数 $ string 的 值 ， 也 没有 影响 
到 函数 外 部 $str 的 值 。 如 果 和 希望 允许 函数 修改 它 的 参数 值 ， 必 须 通过 引用 传递 参数 ， 方 法 
是 在 函数 定义 中 该 参数 的 前 面 预先 加 上 “&” 符 号 。 
修改 上 面 的 代码 如 下 : 


<? php 

function change( & $string) | 
$string = " & 改变 之 后 " ; 

| 

$str = "改变 之 前 " ; 

change( $str); 

echo $str; 


7» 


这 段 代 码 的 输出 为 “改变 之 后 ” 。 在 函数 内 部 改变 了 参数 $string 的 值 ， 也 影响 到 了 函数 
外 部 $str 的 值 。 前 后 两 段 代 码 的 唯一 区 别 就 是 ， 后 面 一 段 代 码 的 参数 传递 是 引用 传递 ， 即 
在 函数 定义 中 的 参数 前 面 加 上 了 “&” 符 号 。 


us 返回 函数 值 


所 有 的 函数 都 可 以 有 返回 值 ， 也 可 以 没有 返回 值 ， 主 要 是 通过 使 用 可 选 的 retum( ) 语 句 
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返回 值 。 任 何 类 型 都 可 以 返回 ， 其 中 包括 列表 和 对 象 。 这 导致 函数 立即 结束 运行 ， 并 且 将 控 
制 权 传递 回 被 调用 的 行 。 
举例 如 下 : 


<? php 
$numl 2100; 
$num2 - 200; 
echo "最 大 的 是 ". maxNum( $numl , $num2) ; // 输出 :最 大 的 是 200 
function maxNum( $a, $b)! 
if( $a« $b) $a= $b; 
return $a; 
| 
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2.8.4 


PHP PEIRO REEM, MAREE, MEELA RKA, AR 
THU P LBE 25 — 1 ERU S EL, C PCR ERU BE TE BL E RRR ZETA 
生效 ， 举 例如 下 : 


<? php 
function foo( ) 
| 
function bar( ) 
| 
echo "并 没有 关闭 直到 foo( ) 函数 被 应 用 ."，; 
| 
| 
/ * WAERED bar( ) 函数 ,因为 它 并 没有 被 关闭 . */ 
foo( ) ; 
/* 现在 可 以 应 用 bar( ) 函数 ， 
foo( ) s 的 进程 允许 使 用 . */ 
bar( ); 


7» 


这 段 代 码 的 输出 为 “并 没有 关闭 、 直 到 foo( ) 函数 被 应 
所 谓 骨 套 调用 ， 就 是 在 调用 一 个 函数 的 过 程 中 ， 数 。 举 例如 下 : 


<? php 

$numl = 100 ; 

$num2 - 200; 

myoutput( $numl, $num2) ; 








function myoutput( $a, $b) | 
echo "最 大 的 是 ". maxNum( $a, $b); 
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| 

function maxNum( $a, $b)! 
if( $a< $b) $a= $b; 
retum $a; 


| 
?> 
这 段 代码 的 输出 是 “最 大 的 是 200”。 在 此 段 代码 中 首先 调用 的 myoutput( ) ， 而 在 调用 
这 个 函数 的 过 程 中 ， 又 调用 了 另 一 个 函数 maxNum( ) ， 这 就 是 函数 的 藤 套 调用 。 
PHP 中 还 允许 函数 的 递归 调用 ， 即 在 调用 一 个 函数 的 过 程 中 又 直接 或 间接 地 调用 
数 本 身 。 举 例如 下 : 


<? php 











ediun ly 
function recursion( $a) 
| 
if( $a<=10)| 
echo " $a"; 
recursion( $a 4-1); 
| 
| 
7» 
这 段 代 码 的 输出 是 数字 5，6, 7,，8,，9，10。 在 此 段 代 码 中 首先 调用 的 recursion( ) ， 而 
在 调用 这 个 函数 的 过 程 中 ， 如 果 参 数 的 值 小 于 等 于 10， 则 又 调用 此 函数 本 身 ， 这 就 是 函数 
的 递归 调用 。 衣 套 和 递归 的 应 用 在 使 用 PHP. 进行 一 些 结算 系统 的 应 用 时 经 常 使 用 到 ， 需 要 
读者 举一反三 ,清晰 地 掌握 逻辑 关系 后 才 可 以 进行 应 用 ， 否 则 经 常 容易 出 现 死 循环 。 





PHP 和 MySQL 数据 库 的 操作 


要 想 快速 成 为 PHP 网 页 编程 高 手 ， 核 心 掌握 PHP 和 MySQL 的 数据 库 操作 是 非常 重要 
的 。 一 般 PHP 实现 对 MySQL 的 操作 主要 包括 连接 、 创 建 、 插 和 入、 选择、 查询、 排序、 更 新 
以 及 删除 等 操作 。 下 面 就 分 别 介绍 一 下 实现 这 些 功 能 的 函数 命令 。 


ULL 连接 数据 库 mysql connect( ) 


在 能 够 访问 并 处 理 数据 库 中 的 数据 之 前 ， 必 须 创 建 到 达 数 据 库 的 连接 。 在 PHP 中 ， 
个 任务 通过 mysql. connect( ) 函数 完成 。 

语法 : mysql, connect ( servername ,username , password ) 

举例 如 下 。 

在 下 面 的 例子 中 ， 在 一 个 变量 中 ($con) 存放 了 在 脚本 中 供 稍 后 使 用 的 连接 。 如 果 连 
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接 失 败 ， 将 执行 die 部 分 。 


<? php 
$conn = mysql. connect( " localhost" , " root" ," admin" ) ; 
if( ! $conn) 

| 

die( 不 能 连接 数据 库 :' . mysql_error( ) ) ; 

| 


7» 
脚本 一 结束 ， 就 会 关闭 连接 。 如 需 提前 关闭 连接 ， 使 用 mysql elose() 函数 实现 。 


<? php 
$conn = mysql. connect( " localhost" ," root" ," admin" ) ; 
if( ! $conn) 
| 
die( 不 能 连接 数据 库 :' . mysql_error( ) ) ; 
| 
mysql. close( $conn) ; 
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2 创建 数据 库 CREATE 


CREATE DATABASE 语句 用 于 在 MySQL 中 创建 数据 库 。 

语法 : CREATE DATABASE database_name 

为 了 让 PHP 执行 上 面 的 语句 ， 必 须 使 用 mysql_query( ) 函数 。 此 函数 用 于 向 MySQL. 连 
接 发 送 查 询 或 命令 。 

举例 如 下 。 

在 下 面 的 例子 中 ， 创 建 了 一 个 名 为 my_db 的 数据 库 : 


<? php 
$conn = mysql. connect( " localhost" ," root" ," admin" ) ; 
if( ! $conn) 
| 
diel 不 能 连接 数据 库 .' . mysql_error( ) ) ; 
| 
if( mysql. query( " CREATE DATABASE my. db" , $conn)) 
| 
echo " Database created" ; 
| 
else 


| 


echo " Error creating database; " 


. mysql error( ) ; 
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mysql. close( $conn ) ; 

7» 
CREATE TABLE 用 于 在 MySQL 中 创建 数据 库 表 。 
BE. 

CREATE TABLE table name 

( 


column, namel data type, 





column, name2 data type, 


column, name3 data type, 


为 了 执行 此 命令 ， 必 须 向 mysql. query ) 函数 添加 CREATE TABLE 语句 。 

举例 如 下 。 

下 例 展 示 了 如 何 创建 一 个 名 为 Persons 的 表 。 此 表 有 3 列 ， 列 名 是 FirstName, LastName 
以 及 Age: 


<? php 
$conn = mysql. connect( " localhost" , " admin" ) ; 
if( ! $conn) 
| 
die( 不 能 连接 数据 库 :' .mysql_error( ) ) ; 
| 
if( mysql. query( " CREATE DATABASE my. db" , $conn)) 
| 


echo " Database created" ; 


| 
else 
| 
echo " Error creating database: 
| 
mysql. select. db( " my. db" , $conn) ; 
$sql = " CREATE TABLE Persons 
( 
FirstName varchar(15) , 
LastName varchar(15) , 


root" ; " 


" . mysql error( ) ; 


Age int 

^3 

mysql. query ( $sql, $conn) ; 
mysql. close( $conn) ; 


?> 


在 创建 表 之 前 ， 首 先 必须 选择 数据 库 。 通 过 mysql select db() 函数 选择 数据 库 。 当 创建 
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varchar 类 型 的 数据 库 字 段 时 ， 必 须 规 定 该 字段 的 最 大 长 度 ， 例 如 varchar( 15) ;, MySQL 各 种 
数据 类 型 表 如 表 2-8 ~ 表 2-11 所 示 。 
表 2-8 MySQL 数据 类 型 表 
数值 类 型 I MEETS 


int( size) 





smallint( size ) 


仅 支 持 整数 
在 size 参数 中 规定 数字 的 最 大 值 


tinyint( size ) 
mediumint( size ) 


bigint( size) 





decimal (size, d) 
double (size, d) 


float (size, d) 


在 size 参数 中 规定 数字 的 最 大 值 。 在 d 参数 中 规定 小 数 点 右 侧 的 数字 的 最 大 值 





表 2-9 文本 数据 类 型 表 

文本 数据 类 型 描 $ 

支持 固定 长 度 的 字符 串 。( 可 包含 字母 、 数 字 以 及 特殊 符号 ) 
在 size 参数 中 规定 固定 长 度 

支持 可 变 长 度 的 字符 串 ( 可 包含 字母 、 数 字 以 及 特殊 符号 ) 
在 size 参数 中 规定 最 大 长 度 





char( size) 








varchar( size ) 






































tinytext 支持 可 变 长 度 的 字符 串 ， 最 大 长 度 是 255 个 字符 
text gem L^ Hed ez Ag EB L^ Hg] cL 
o 支持 可 变 长 度 的 字符 串 ， 最 大 长 度 是 65535 个 字符 
DIOD 
mediumtext — P ay pea 2z 
oe 支持 可 变 长 度 的 字符 串 ， 最 大 长 度 是 16777215 个 字符 
ImedlumDlo. 
longtext TROP E^ Hg Az 
Mods 支持 可 变 长 度 的 字符 串 ， 最 大 长 度 是 4294967295 个 字符 
ongblo 





表 2-10 日 期 数据 类 型 表 
日 期 数据 类 型 描 述 





date (yyyy - mm - dd) 
datetime (yyyy - mm - dd hh; mm; ss) 


支持 日 期 或 时 间 


timestamp. ( yyyymmddhhmmss ) 


time (hh; mm; ss) 





表 2-11 杂项 数据 类 型 表 














杂项 数据 类 型 描述 
enum( valuel , value2 , ect) enum 是 enumerated 列表 的 缩写 。 可 以 在 括号 中 存放 最 多 65535 个 值 
set set 与 enum 相似 。 但 是 ，set 可 拥有 最 多 64 个 列表 项 目 ， 并 可 存放 不 止 一 个 choice 


每 个 表 都 应 有 一 个 主键 字段 。 主 键 用 于 对 表 中 的 行进 行 唯一 标识 ， 每 个 主键 值 在 表 中 必 
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须 是 唯一 的 。 此 外 ， 主 键 字段 不 能 为 空 ， 这 是 由 于 数据 库 引 擎 需要 一 个 值 来 对 记录 进行 定 
位 。 主 键 字 段 永 远 要 被 编 人 索引 ， 这 条 规则 没有 例外 ， 必 须 对 主键 字段 进行 索引 ， 这 样 数据 
库 引 擎 才能 快速 定位 给 予 该 键 值 的 行 。 

下 面 的 例子 把 personID 字段 设置 为 主键 字段 。 主 键 字段 通常 是 ID 号 ， 且 通常 使 用 
AUTO. INCREMENT 设置 。AUTO_INCREMENT 会 在 新 纪录 被 添加 时 逐一 增加 该 字段 的 值 。 
要 确保 主键 字段 不 为 空 ， 必 须 向 该 字段 添加 NOT NULL 设置 。 

举例 如 下 。 


$sql = "CREATE TABLE Persons 

( 

personID int NOT NULL AUTO INCREMENT, 
PRIMARY KEY( personID) , 

FirstName varchar(15) , 

LastName varchar(15) , 





Age int 
)"s 
mysql. query( $sql, $conn) ; 


URS 插入 数据 INSERT INTO 


INSERT INTO 语句 用 于 向 数据 库 表 添加 新 记录 。 
语法 : 

INSERT INTO table name 

VALUES( valuel ,value2 ,…) 


还 可 以 规定 希望 在 其 中 插入 数据 的 列 : 


INSERT INTO table name( columnl ,column2 ,… 
VALUES( valuel ,value2 ,…) 


SQL 语句 对 大 小 写 不 敏感 。INSERT INTO 5j insert into 相同 。 为 了 让 PHP 执行 该 语句 ， 
必须 使 用 mysql_query( ) 函数 。 该 函数 用 于 向 MySQL. 连接 发 送 查 询 或 命令 。 

举例 如 下 。 

在 前 面 创建 了 一 个 名 为 Persons 的 表 ， 有 3 列 : Firstname, Lastname 以 及 Age。 将 在 下 例 
中 使 用 同样 的 表 。 下 面 的 例子 向 Persons 表 添 加 了 2 个 新 记录 : 


<? php 
$conn = mysql. connect( " localhost" ," root" ," admin" ) ; 
if( ! $conn) 

| 

die( 不 能 连接 数据 库 :' .mysql_error( ) ) ; 

| 


mysql. select. db( " my. db" , $conn) ; 
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mysql. query( " INSERT INTO Persons( FirstName , LastName , Age ) 
VALUES( chen | yicai | 35 )"); 

mysql. query ( " INSERT INTO Persons( FirstName , LastName , Age ) 
VALUES( yu | heyud ，28 )"); 

mysql. close( $conn) ; 
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"UE 选取 数据 SELECT 


SELECT 语句 用 于 从 数据 库 中 选取 数据 。 
语法 : 
SELECT column, name( s) FROM table, name 


为 了 让 PHP 执行 上 面 的 语句 ， 必 须 使 用 mysql. query ) 函数 。 该 函数 用 于 向 MySQL 发 送 
查询 和 命令 。 

举例 如 下 。 

下 面 的 例子 选取 存储 在 Persons 表 中 的 所 有 数据 ( * 字符 选取 表 中 所 有 数据 ) : 


<? php 
$conn = mysql. connect( " localhost" ," root" ," admin" ) ; 
if( ! $conn) 

| 

die( 不 能 连接 数据 库 :' . mysql_error( ) ) ; 

| 
mysql. select. db( " my. db" , $conn) ; 
$result = mysql_query ( "SELECT * FROM Persons" ) ; 
while( $row = mysql. fetch. array(. $result) ) 


| 


echo $row[ FirstName ] . " ". $row| LastName ]; 


echo " <br/>"; 


| 


mysql_close( $conn) ; 
To 
上 面 这 个 例子 在 $ result 变量 中 存放 由 mysql. query ( ) 函数 返回 的 数据 。 接 下 来 ,使 用 
mysql. fetch, array ( ) 函数 以 数组 的 形式 从 记录 集 返 回 第 1 行 。 随 后 对 mysql_fetch_array( ) 函数 
的 每 次 调用 都 会 返回 记录 集中 的 下 一 行 。while loop 语句 会 循环 记录 集中 的 所 有 记录 。 为 了 
输出 每 行 的 值 , 使 用 了 PHP 的 $row 变量 ( $row[ FirstName ] 和 $row[ LastName ] )。 


UL 条 件 查 询 WHERE 


如 需 选 取 匹 配 指定 条 件 的 数据 ， 请 向 SELECT 语句 添加 WHERE 子 句 。 
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语法 : 


SELECT column FROM table 
WHERE column operator value 


下 面 如 表 2-12 所 示 的 运算 符 可 与 WHERE 子 句 一 起 使 用 。 
表 2-12 可 用 于 查询 的 运算 符 



































m 算 符 说 明 i: 算 符 说 Hj 
z 等 于 >= 大 于 或 等 于 
! = 不 等 于 < 小 于 或 等 于 
> 大 于 BETWEEN 介 于 一 个 包含 范围 内 
< 小 于 LIKE 搜索 匹配 的 模式 





为 了 让 PHP 执行 上 面 的 语句 ， 必 须 使 用 mysql. query ) 函数 。 该 函数 用 于 向 SQL 连接 发 
送 查 询 和 命令 。 

举例 如 下 。 

下 面 的 例子 将 从 Persons 表 中 选取 所 有 FirstName = Root. 的 行 : 


<? php 
$conn = mysql. connect( " localhost" , " root" ," admin" ) ; 
if( ! $conn) 

| 

diel 不 能 连接 数据 库 .' . mysql error( ) ) ; 

| 
mysql. select. db( " my. db" , $conn) ; 
$result = mysql. query(" SELECT * FROM Persons 
WHERE FirstName = chen "); 


while( $row = mysql_fetch_array( $result) ) 
| 
echo $row[ FirstName ]. " ". $row[ LastName |]; 
echo " <br/>"; 


| 
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Acro 数据 排序 ORDER BY 


ORDER BY 关键 词 用 于 对 记录 集中 的 数据 进行 排序 。 
语法 : 
SELECT column_name(s) 


FROM table_name 
ORDER BY column_name 
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举例 如 下 。 
下 面 的 例子 选取 persons 表 中 存储 的 所 有 数据 ， 并 根据 Age 列 对 结果 进行 排序 : 


<? php 
$conn = mysql. connect( " localhost" ," root" ," admin" ) ; 
if( ! $conn) 
| 
die( 不 能 连接 数据 库 :' .mysql_error( ) ) ; 
| 
mysql. select. db( " my. db" , $conn) ; 
$result = mysql_query ( " SELECT * FROM Persons ORDER BY Age") ; 
while( $row = mysql. fetch, array( $result) ) 
| 
echo $row[ FirstName ]; 
echo " ". $row[ LastName ]; 
"",. $row| Age ]; 
echo " <br/>"; 


| 


mysql. close( $conn) ; 


echo 
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如 果 使 用 ORDER BY 关键 词 ， 记 录 集 的 排序 顺序 默认 是 升序 (1 在 9 之前, a 在 p 之 
前 ) 。 使 用 DESC 关键 词 来 设 定 降序 排序 (9 在 1 之 前 , p 在 a 之 前 ): 


SELECT column, name( s) 
FROM table. name 
ORDER BY column, name DESC 


可 以 根据 两 列 进 行 排序 ， 也 可 以 根据 多 个 列 进行 排序 。 当 按照 多 个 列 进行 排序 时 ， 只 有 
第 1 列 相 同时 才 使 用 第 2 90; 
SELECT column_name(s) 


FROM table. name 


ORDER BY column, namel , column, name2 


"ucro 更 新 数据 UPDATE 


UPDATE 语句 用 于 在 数据 库 表 中 修改 数据 。 
语法 : 
UPDATE table_name 


SET column_name = new_value 


WHERE column_name = some_value 
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SQL 对 大 小 写 不 敏感 ，UPDATE 与 update 等 效 。 为 了 让 PHP 执行 上 面 的 语句 ， 必 须 使 
用 mysql. query () 函数 。 该 函数 用 于 向 SQL 连接 发 送 查 询 和 命令 。 

举例 如 下 。 

下 面 的 例子 更 新 Persons 表 的 一 些 数据 : 


<? php 


e 





$conn = mysql. connect( " localhost" ," root" ," admin" ) ; 


if( ! $conn) 

| 

die( 不 能 连接 数据 库 :' .mysql_error( ) ) ; 

| 
mysql. select. db( " my. db" , $conn) ; 
mysql query( " UPDATE Persons SET Age = 38 
WHERE FirstName 2 chen AND LastName 2 yicai. "); 
mysql_close( $conn) ; 
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2c MREŽE DELETE FROM 


DELETE FROM 语句 用 于 从 数据 库 表 中 删除 记录 。 
BE. 


DELETE FROM table name 





WHERE column. name = some. value 


Aj rib PHP 执行 上 面 的 语句 ， 必 须 使 用 mysql. query () 函数 。 该 函数 用 于 向 SQL 连接 发 
送 查 询 和 命令 。 
举例 如 下 。 


<? php 
$conn = mysql. connect( " localhost" ," root" ," admin" ) ; 
if( ! $conn) 
| 
die( 不 能 连接 数据 库 :' .mysql_error( ) ) ; 
| 
mysql. select. db( " my. db" , $conn) ; 
mysql query( " DELETE FROM Persons WHERE LastName 2 yical "); 
mysql. close( $conn) ; 
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本 小 节 介 绍 了 PHP 实现 MySQL 数据 库 的 一 些 常用 操作 ， 读 者 在 学 习 的 时 候 一 定 要 认真 
编写 每 一 行 的 代码 ， 养 成 良好 的 规范 ， 方 便 今 后 的 提高 学 习 。 
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对 于 初学 者 而 言 ， 学 习 PHP 入 门 最 好 的 方法 就 是 使 用 Dreamweaver 配合 MySQL 进行 动 
态 系统 的 开发 。 之 所 以 说 它 是 最 好 的 方法 是 因为 可 以 用 Dreamweaver 内 置 的 服务 器 行为 将 静 
态 的 网 页 和 后 台 的 MySQL 数据 库 关 联 起 来 ， 成 为 动态 的 PHP AR, Dreamweaver 提供 了 方 
便 的 图 形 化 界面 ， 只 需 使 用 鼠标 选择 ， 输 入 一 些 基本 设置 参数 就 能 够 与 MySQL 数据 库 交 互 ， 
实现 建立 数据 、 查 询 记录 、 新 增 记 录 、 更 新 记录 、 删 除 记录 等 操作 ， 简 单 地 说 ， 不 用 自己 写 
程序 即 可 以 实现 Dreamweaver + MySQL 动态 系统 的 开发 。 本 章 将 介绍 如 何 使 用 这 些 服务 器 行 
为 ， 引 导 大 家 去 阅读 由 Dreamweaver 所 产生 的 程序 代码 ， 了 解 Dreamweaver 的 程序 逻辑 ， 同 
时 掌握 PHP 动态 网 页 开发 的 基础 和 一 些 重要 的 概念 。 





m MATIE i 


主要 掌握 以 下 知识 点 


掌握 Dreamweaver 进行 PHP 开发 的 流程 
搭建 PHP 动态 系统 开发 的 平台 

检查 数据 库 记 录 的 常见 操作 
编辑 记录 的 常见 操作 
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Dreamweaver 动态 网 页 制作 步骤 


使 用 Dreamweaver 中 的 服务 器 行为 可 以 快速 实现 PHP, ASP 以 及 JSP 等 动态 网 站 的 功能 
开发 。 对 于 初学 者 而 言 不 用 掌握 相关 的 程序 编写 ， 只 需要 掌握 一 定 的 操作 顺序 ， 了 解 相 关 的 
服务 器 行为 即 可 以 轻松 实现 动态 网 站 的 建设 。 设 计 使 用 Dreamweaver 成 功 进行 PHP 动态 网 页 
的 制作 并 创建 一 个 动态 Web 站 点 ， 可 以 用 如 下 几 个 关键 步骤 来 进行 。 

一 、 设 计 静 态 PHP 页 面 

在 设计 任何 Web 站 点 (无 论 是 静态 的 还 是 动态 的 ) 时 的 一 个 关键 步骤 是 页 面 视 觉 效 果 
的 设计 。 当 向 网 页 中 添加 动态 元 素 时 ， 页 面 的 设计 对 于 其 可 用 性 至 关 重 要 。 要 仔细 考虑 用 户 
将 如 何 与 各 个 页 面 和 整个 Web 站 点 进行 交互 。 

将 动态 内 容 合 并 到 网 页 的 常用 方法 是 创建 一 个 显示 内 容 的 表格 ， 然 后 将 动态 内 容 导 入 该 
表格 的 一 个 或 多 个 单元 格 中 。 利 用 此 方法 ， 可 以 用 一 种 结构 化 的 格式 来 表示 各 种 类 型 的 
信息 。 

二 、 创 建 动态 内 容 源 

动态 Web 站 点 需要 一 个 内 容 源 ， 在 将 数据 显示 在 网 页 上 之 前 ， 动 态 Web 站 点 需要 从 该 
内 容 源 提 取 这 些 数 据 。 能 在 网 页 中 使 用 内 容 源 之 前 ， 必 须 执 行 以 下 操作 。 

1) 创建 动态 内 容 源 (如 数据 库 ) 与 处 理 该 页 面 的 应 用 程序 服务 器 之 间 的 连接 。 使 用 
“ 绑 定 ” 面 板 创建 数据 源 ， 然 后 可 以 选择 数据 源 并 将 其 插 人 到 页 面 中 。 

2) 通过 创建 记录 集 ， 指 定 要 显示 的 数据 库 中 的 信息 ， 或 指定 希望 在 该 页 面 中 包括 的 变 
量 。 还 可 以 在 记录 集 对 话 框 内 测试 查询 ， 并 可 以 进行 任何 必要 的 调整 ， 然 后 再 将 其 添加 到 
“ 绑 定 ”面板 。 

3) 选择 动态 内 容 元 素 并 将 其 插入 到 选 定 页 面 。 

三 、 向 网 页 添加 动态 内 容 

定义 记录 集 或 其 他 数据 源 并 将 其 添加 到 “ 绑 定 ”面板 后 ， 可 以 将 该 记录 集 所 代表 的 动 
态 内 容 插 入 到 页 面 中 。Dreamweaver 的 菜单 驱动 型 界面 使 得 添加 动态 内 容 元 素 非 常 简单 ， 只 
需 从 “ 绑 定 ”面板 中 选择 动态 内 容 源 ， 然 后 将 其 插入 到 当前 页 面 内 的 相应 文本 、 图 像 或 表 
单 对 象 中 即 可 。 

将 动态 内 容 元 素 或 其 他 服务 器 行为 插入 到 页 面 中 时 ，Dreamweaver 会 将 一 段 服务 器 端 和 
本 搬入 到 该 页 面 的 源 代 码 中 。 该 脚本 指示 服务 器 从 定义 的 数据 源 中 检索 数据 ， 然 后 将 数据 呈 
现在 该 网 页 中 。 若 要 在 网 页 中 放置 动态 内 容 ， 请 执行 以 下 操作 之 一 。 

1) 将 其 放 在 “代码 ”视图 或 “设计 ”视图 中 的 插入 点 处 。 

2) 替换 文本 字符 串 或 其 他 占 位 符 。 

3) 将 其 插入 到 HTML 属性 中 。 例 如 ， 动 态 内 容 可 以 定义 图 像 的 ere 属性 或 表单 域 的 
value 属性 。 

四 、 向 页 面 添 加 服务 器 行为 

除了 添加 动态 内 容 外 ， 还 可 以 通过 使 用 服务 器 行为 将 复杂 的 应 用 程序 逻辑 结合 到 网 页 
中 。 服 务 器 行为 是 预定 义 的 服务 器 端 代码 片段 ， 这 些 代码 向 网 页 添加 应 用 程序 逻辑 ， 从 而 提 
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PHP*MySQL Dreamweaver 


供 更 强 的 交互 性 能 和 功能 。 

Dreamweaver 服务 器 行为 可 以 向 Web 站 点 添加 应 用 程序 逻辑 ， 而 不 必 亲 自 编 写 代 码 。 随 
Dreamweaver 提供 的 服务 器 行为 文 持 ColdFusion, ASP 和 PHP 文档 类 型 。 服 务 器 行为 经 过 精 
心 编写 和 仔细 测试 ， 达 到 快速 、 安 全 和 可 靠 的 目的 。 内 置 服务 器 行为 支持 跨 平台 网 页 ， 适用 
于 所 有 浏览 

Dreamweaver 提供 指向 并 单 击 (point - and - click) 界面 ， 这 种 界面 使 得 将 动态 内 容 和 
复杂 行为 应 用 到 页 面 就 像 插 入 文本 元 素 和 设计 元 素 一 样 简 单 。 可 使 用 的 服务 器 行为 如 下 
所 述 。 

1) 定义 来 自 现 有 数据 库 的 记录 集 。 所 定义 的 记录 集 随 后 存储 在 “ 绑 定 ”面板 中 。 

2) 在 一 个 页 面 上 显示 多 条 记录 。 可 以 选择 整个 表 、 包 含 动态 内 容 的 各 个 单元 格 或 各 
行 ， 并 指定 要 在 每 个 页 面 视 图 中 显示 的 记录 数 。 

3) 创建 动态 表 并 将 其 插入 到 页 面 中 ， 然 后 将 该 表 与 记录 和 集 相关 联 。 以 后 可 以 分 别 使 用 
属性 检查 器 和 重复 区 域 服务 器 行为 来 修改 表 的 外 观 和 重复 区 域 。 

4) 在 页 面 中 插入 动态 文本 对 象 。 插 入 的 文本 对 象 是 来 自 预 定义 记录 和 集 的 项 ， 可 以 对 其 
应 用 任何 数据 格式 。 

5) 创建 记录 导航 和 状态 控件 、 主 /详细 页 面 以 及 用 于 更 新 数据 库 中 信息 的 表单 。 

6) 显示 来 自 数据 库 记 录 的 多 条 记录 。 

7) 创建 记录 集 导航 链接 ， 这 种 链接 允许 用 户 查 看 来 自 数据 库 记 录 的 前 面 或 后 面 的 
记录 。 

8) 添加 记录 计数 器 ， 以 帮助 用 户 跟 踪 返 回 的 记录 数 以 及 其 在 返回 结果 中 所 处 的 位 置 。 

9) 还 可 以 通过 编写 自己 的 服务 器 行为 或 者 安装 由 第 三 方 编写 的 服务 器 行为 来 扩展 Dre- 
amweaver 服务 器 行为 。 

五 、 测 试 和 调试 页 面 

在 将 动态 页 或 整个 Web 站 点 发 布 到 Web 上 之 前 ， 应 首先 测试 其 功能 。 通 过 测试 可 以 检 
查 程序 开发 的 结果 ， 如 果 出 现 错误 要 及 时 进行 更 改 。 















































搭建 PHP 动态 系统 平台 





上 述 的 PHP 动态 网 页 开发 其 实 很 简单 ， 本 章 就 以 实例 的 形式 具体 介绍 Dreamweaver 中 服 
务 需 行为 的 使 用 方法 。 在 开始 制作 一 个 PHP 网 站 之 前 ， 需 要 在 Dreamweaver 中 定义 一 个 新 网 
站 。 在 “新 建站 点 ”中 可 以 让 Dreamweaver 知道 现在 的 网 站 本 地 目录 及 测试 的 路 径 等 信息 ， 
另外 一 项 工作 就 是 数据 库 的 创建 工作 。 





系统 结构 设计 


"PHP 动态 功能 ”的 系统 结构 设计 如 图 3-1 所 示 。 本 系统 主要 的 结构 分 成 用 户 登 录入 口 
与 找 回 密码 入 口 两 个 部 分 ， 其 中 index. php 是 这 个 网 站 的 首页 。 





动态 网 站 开发 从 入 门 到 精通 
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detail.php 





图 3-1 PHP 动态 系统 结构 图 


在 本 地 的 计算 机 设置 站 点 服务 器 ， 在 Dreamweaver CC 的 网 站 环境 中 可 以 按 (F12) 键 来 
浏览 网 页 ， 还 可 以 在 IE 浏览 器 输入 “http://localhost/phpweb/index. php” 来 打开 用 户 系统 
的 首页 index. php, HEP phpweb 为 站 点 名 。 

在 实例 中 ,会 使 用 到 以 下 5 个 页 面 ， 整 个 网 站 的 架构 就 如 表 3-1 所 示 。 


表 3-1 PHP 动态 功能 网 页 设计 表 

















































































































页 面 名 称 功 能 页 面 名 称 Xj 能 
index. php 系统 首页 用 来 显示 记录 清单 update. php 更 新 记录 页 
detail. php 显示 记录 详细 信息 页 del. php I 除 记录 页 

add. php 添 增 记录 页 面 

















index. php 用 于 浏览 数据 库 内 记录 ， 为 detail. php 提供 附带 URL 参数 ID 的 超级 链接 ， 便 
于 查看 详细 的 记录 信息 ， 如 图 3-2 所 示 。 






























































































































































Jak 
(B http://localhost/phpweb/index.php go-8Óx | no 
ET = 
PHP 动 态 系统 
共有 10 笔记 录 ， 目 前 查看 第 1 笔 至 第 5 笔 
序号 姓名 年 龄 成 绩 
l testi 21 100 
2 test2 22 98 E 
3 test3 22 86 
4 test4 21 89 
5 test5 23 74 
[下 一 页 ] [最 后 一 页 ] 




















图 3-2 index 页 面 效 果 


detail. php 用 于 接收 由 index. php 传 来 的 URL 参数 ID, ， 利 用 URL 参数 筛选 数据 库 中 的 记 
录 。 更 新 与 删除 记录 都 是 依据 数据 库 中 的 主键 字段 ID 来 识别 记录 的 ， 如 图 3-3 所 示 。 

当 制 作 一 个 PHP 动态 网 站 时 ， 事 前 规划 网 站 的 架构 是 一 件 很 重要 的 事情 。 这 个 网 站 
在 设计 人 员 的 脑子 里 要 有 一 个 和 雏形， 如 大 概 有 哪些 页 面 、 页 面 间 的 关系 如 何等 。 数 据 库 
的 架构 规划 也 是 一 样 的 ， 如 要 有 哪些 数据 表 、 字 段 ， 如 何 跟 网 页 配合 等 ， 都 是 很 重要 的 
事情 。 
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PHP 动 态 系统 
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图 3-3 detail. php 页 面 效 果 


suu 创建 用 户 数据 库 


PHP 动态 系统 的 功能 分 析 发 现 ， 这 个 数据 库 应 该 包括 中、 姓名 、 年 龄 、 成 绩 4 个 字段 。 
所 以 在 数据 库 中 必须 包含 一 个 容纳 上 述 信息 的 表 ， 将 数据 库 命 Eo pen: 接 下 来 要 在 
MySQL 建立 网 站 数据 库 作为 任何 数据 查询 、 新 增 、 修 改 与 删除 的 后 端 支持 。 制 作 的 步骤 如 下 。 

1) 在 正 浏览 器 中 输入 “http://127.0.0.1/phpmyadmin/”， 输入 MySQL 的 用 户 名 和 密 
人 码 (xammp 默认 环境 下 可 以 直接 登录 ) 。 单 击 “ 执 行 ” 按 钮 即 可 以 进入 软件 的 管理 界面 ， 选 
e E 可 进行 表 、 字 有 段 的 增删 改 ， 可 以 导入 、 导 出 数据 库 信 
息 ， 如 图 3-4 所 示 。 
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图 3-4 软件 的 管理 界面 
2) 单 击 电 数据 库 命 令 ， 打 开本 地 的 “数据 库 ” 管 理 页 面 ， 在 “新 建 数据 库 ” 文 本 框 中 
输入 数据 库 的 名 称 phpweb， 单 击 后 面 的 数据 库 类 型 下 拉 列 表 框 ， 在 弹出 的 下 拉 菜 单 中 选择 
utf8 general ci 选项 ， 如 图 3-5 所 示 。 
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图 3-5 “数据 库 ” 的 管理 界面 

UTF8 是 数据 库 的 编码 格式 ， 通 常 在 开发 PHP 动态 网 站 的 时 候 Dreamweaver 默认 的 格式 

就 是 UTF8 格式 ， 在 创建 数据 库 的 时 候 也 要 保证 数据 库 储 存 的 格式 和 网 页 调用 的 格式 一 样 ， 

这 里 要 介绍 一 下 utf8_bin 和 utf8_general_ci 的 区 别 。 其 中 ci 是 case insensitive ， 即 “大 小 写 不 
敏感 "，a 和 A 在 字符 判断 中 会 被 当做 一 样 的; bin 是 二 进 制 ，a 和 A 会 被 区 别 对 待 。 

3) 单 击 “ 创 建 ” 按 钮 ， 返回 “常规 设置 ”页 面 ， 在 数据 库 列 表 中 就 已 经 建立 了 php- 

web 的 数据 库 ， 如 图 3-6 所 示 。 
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phpMyAdmin KDE 
$a40o0€ j 数据 库 O SQL ARS SA 3 Sho) SAO ^ WE 复制 o 变量 v 更 多 




































































GünteRO . — [m - 

eremo. ia 常规 设置 数据 库 服务 器 

8-3 cdcol mmm = , 

meaa nana = 服务 器 连接 排序 规则 © :| utf8_general_ci zl - 服务器: 127.0.0.1 via TCP/IP 

Qa mysql 服务 器 类 型 : MySQL 

3 "d | 

&- aj performance schema . Ee s 14 - MySQL Community I 
| ac) phpmyadmin 外 观 设置 AEE 

"uS uU * AP: root@localhost 

eG webauth & 语言 -Language 画 :| 中 文 - Chinese simplified E - 服务 器 字符 集 : UTF-8 Unicode (utf8) 
































地 主题 :| pmahomme |. | | 
- 字号 :| 82% 国 | 网 站 服务 器 | 


P ERE - Apache/24.7 (Win32) Openssu1.0.1e | 
PHP/5.5.6 

- Xie peer FR: ibmysql - mysqind 
5.0.11-dev - 20120503 - $Id: 
40933630edef551dfaca71298a83fad8d03d€ 
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* PHP}: mysqli © 


phpMyAdmin 


* 版 本 信息 : 4.0.9， 最 新 稳定 版 本 : 430 Ue 
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图 3-6 创建 
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4) 数据 库 建 立 后 还 要 建立 网 页 数据 所 需 的 数据 表 。 网 站 数据 库 的 数据 表 是 websql。 
立 数据 库 后 ， 接 着 单 击 左边 的 phpweb 数据 库 将 其 连接 上 ， 如 图 3-7 所 示 。 


ra 


动态 网 站 开发 从 入 门 到 精通 
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kea) 
Oo MA ~ | Ah http://127.0.0.1/phpmyadmin/#PMAURL-7:db_structure.php?db=phpweb&table=&server=1&target=&token=6c099c14abc2084a d? O~ X| (5) 1r i9 
4i 127.0.0.1 / 127.0.0.1 / ph.. x [,.] 
phpMyAdmin i-| ARZE: 127.0.0.1 > @ 数据库: phpweb 
$890€ Wes B sa S HER om (2 tho 图 导入 4 BHE SRR S EO v 更 多 
(dust). E — etpictuasereiteb 
8-3 cdcol | MEER | 
G3 information schema —á—— 
GH 3 mysql T "S 
G-a performance_schema Ee | | 字段 数 : | 
GH s phpmyadmin 
e J phpweb | 
E 区 
ea test f | 
(75 webauth za) 
= J 
图 3-7 开始 建 数据 表 





5) 打开 数据 库 右 方 夯 面 会 出 现 “ 新 建 数 据 表 ”的 设置 区 域 , 含有 “名 字 ”、 


两 个 文本 框 ， 在 “名 字 ” 中 输入 数据 表 名 websql， 


f 


“字段 数 ” 


“字段 数 ” 文 本 框 中 输入 本 数据 表 的 字段 
数 为 4， 表 示 将 创建 4 个 字段 来 储存 数据 ， 如 图 3-8 所 示 。 








QO 





), http://127.0.0.1/phpmyadmin/s$PMAURL-7:db structure.php?db - phpweb&table-&serverzl&target-&token-6c099cl4abc2084a d? O~ CX| (5) vy. i93 
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| ERIR) - 














Ha cdcol 

w 3 information schema 
3 mysql 

Ga performance_schema 

Fa ; phpmyadmin 

È H) phpweb 
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era j test 

EH 3J webauth 








图 ARA: 127.0.0.1» EU phpweb 
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6) 再 单 击 “执行 ”按钮 ， 


录 每 个 人 的 基本 信息 和 





3-8 输入 数据 表 名 websql 和 字段 数 





成 绩 o 





切换 到 数据 表 的 字段 属性 设置 页 面 ， 输 入 数据 域名 以 及 设置 
数据 域 位 的 相关 数据 ， DAJ 9 所 示 。 各 字段 的 意义 如 表 3-2 Bros, X 


这 个 数据 表 主 要 是 记 















































































































































































































































Y e = > 
SE > e 0 第 3 章 Dreamweaver+PHP 开 发 基础 
表 3-2 websql 数据 表 
字段 名 称 字段 类 型 字段 大 小 说 H 
ID int 11 自动 编号 
name varchar 20 个 人 姓名 
age tinyint 4 个 人 年 龄 
Result varchar 20 个 人 成 绩 
lla) 
MA 7 | Ma http://127.0.0.1/phpmyadmin/#PMAURL-8:tbl_create.php?db=phpweb&table=websql&server= 1&target=&token=6c099c14abc2084a6e794c3aa19d40ac è PpP-ex| i YT Ba 
id 127.0.0.1 / 127.0.0.1 / ph... X 
phpMyAdmin m EE = — TERS — 
$9006 E] 浏览 He E sal x HO KNA (i9 Wh D 导入 | BH Dee co MAS 
| GERBER) z| — gexa: [webs | mn 个 字段 (执行 
Es EET 
a " Toii ma pu AN o Kb o 默认 已 排序 规则 属性 X d 
e performance schema ID | INT. - [n | 无 - = | w| 回 
La J phpmyadmin 一 一 一 一 一 一 D " 

9: : bc (mme | |VARCHAR a| [o | 天 z| | z) | w| 日 
=a webauth p= z 一 = = m iB 
= age | TINYINT x [a | x x x | I w| 

Result a VARCHAR xj [20 IE z| | x] | wj B 
do 存储 引擎 : o 排序 规则 : 
MyISAM x)| [ zl 
分 区 定义 : o 
PE m — — - Le 






































图 3-9 设置 数据 库 字 段 属性 


7) 最 后 再 单 击 “保存 ”按钮 ， 切 换 到 “结构 ”页 面 。 将 要 使 用 的 数据 库 建立 完毕 ， 如 


图 3-10 所 示 。 
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一 、 
| 人 7 | 4i, http//127.0.0.1/phpmyadmin/PMAURL-11:tbl structure.php?db- phpweb&table-websgl&server-i&target-&token-6c099c1dabc20: $ PCx| Ù vv i93 
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phpMyAdmin 
$9e€ 
| Gif tra RS). - 
Ha cdcol 
$ a information schema 
=a mysql 


e 
H performance schema 


a phpmyadmin 
M- 4 phpweb 
EE 
i+- | websql 
LA a test 
[+ a webauth 








图 ARAE: 127.0.0.1» @ ŽRE: phpweb » [M 2: websql 
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# 名 字 ”类 型 排序 规则 属性 空 默认 AR 操作 
A 11D int(11) 否 无 JE QN Jiu xxl E Ta v ER 
2 name varchar(20) utf8 general ci Sx 2 Ei QI o Eeu 5l? Ei] 更 多 
回 3 age  tinyint(4) 否 无 只 修改 QNM A tmi ga E a 更 多 
4 Result varchar(20) utf8 general ci SE s^) QI o Heu gA [? ril vw 8 
t DOSi zem. 国 浏览 Jea Omè A B- Bal E TH 
T 全 文 搜索 





& HR da 关系 查看 M 规划 表 结 构 9 
Em |1 | AFRO TAE OCDE 


D 追踪 表 Bum 
头目 于 之 后 ID [e] (hr) 
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创建 时 间 2014-12-07 20:12:54 
最 后 更 新 2014-12-07 20:12:54 


+ 索引 

[me | 
已 用 空间 Row statistics 
数据 0 字 节 格式 动态 | 
索引 1 KB 排序 规则 utf8 general ci | 
总 计 1 KB 行 数 0 | 
| 
| 
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8) 为 了 页 面 制作 的 调用 需要 ， 可 以 先 在 数据 表 里 加 入 10 笔 数据 ， 在 数据 表 手 动 加 入 
名 为 testl ~ test10 的 10 个 测试 姓名 ， 年 龄 和 成 绩 也 编辑 不 同 的 数据 ， 如 图 3-11 所 示 。 



















































































































































































pt cac 
( eo) 个 人 | 的 http://127.0.0.1/phpmyadmin/server databases.php?db-&table-&server-l&target-&token-6c099c14abc2084a6e794c3aal9d40act È O- CX| (3 vy i9: 
ii 127.0.0.1 / 127.004 / ph... x [| 
phpMyA dmin 图 ARSE: 127.0.0.1» Ø X: phpweb » P 
OBonse 司 浏览 M ga O sa 又 搜索 EIM 图 导出 g SA A RE D XS c5 触发 器 
| 最近 使 用 的 表 ) . x 
一 显示 : 起 始 行 : 10 meo | 每 |100 | 行 重复 表 头 
e j cdcol 3 
G3 information schema 按 索 引 排序 :| 无 -l 
Ha mysql A 
H3 performance. schema RR 
"- j phpmyadmin -T> v ID name age Result 
E3 phpweb IRE KAR QUINOS 1 test! | 21 100 
Fase J JAR HAR OMA 2 test2 | 22 98 | 
*- | websql z 
Thr — 7| JRB Rel OMR 3 test3 | 22/86 
E webauth T ^B EAR OMR 4 test4 | 21 89 
JRE KER QR 5 test5 | 23 74 
O ?编辑 KEH 加 删除 6 testo | 21 66 
rj JRA KEH @ WMA 7|test7 | 22/95 
< 编辑 KER QE stes 2387 n 
司 JRA HEH QE 9jtest9 | 24/69 
< 编辑 KER QUE 10 test10 23 70 
t $iko— mem y (mo ONE BFH 
显示 : 起 始 行 : | 0 ín |30 — |& | 100 — | 行 重复 表 类 








图 3-11 加 入 10 笔 数 据 


SES 定义 phpweb 站 点 


在 Dreamweaver CC 中 创建 一 个 “PHP 动态 系统 ”网 站 站 点 phpweb， 由 于 这 是 PHP 数据 
库 网 站 ， 因 此 必须 设置 本 机 数据 库 和 测试 服务 器 ， 主 要 的 设置 如 表 3-3 所 示 。 


表 3-3 站 点 设置 的 基本 参数 


























站 点 名 称 phpweb 站 点 名 称 phpweb 
本 机 根 目录 C:\xampp\htdocs\phpweb MySQL 服务 器 地 址 C: \xampp\mysql \ data\phpweb 
测试 服务 器 C:\xampp\htdocs\ 管理 账号 /密码 root/ 空 
网 站 测试 地 址 http ;//localhost/ phpweb/ 数据 库 名 称 websql 


创建 phpweb 站 点 具体 操作 步骤 如 下 。 

1) 首先 在 C; \xampp\htdocs 路 径 下 建立 phpweb 文件 夹 ， 如 图 3-12 所 示 ， 本 章 所 有 建 
立 的 网 页 文件 都 将 放 在 该 文件 夹 下 。 

2) 运行 Dreamweaver CC， 选 择 菜 单 栏 中 的 “站 点 ”一 “管理 站 点 ”命令 ， 打开“ 管理 
站 点 ”对 话 框 ， 如 图 3-13 所 示 。 

3) 单 击 右边 的 “新 建站 点 ”按钮 ， 打 开 “ 站 点 设置 对 象 ”对 话 框 ， 进 行 如 下 参数 


设置 。 
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í EE) 
gO- |j « Acer (C) » xampp » htdocs » "| i85 htdocs p 
; XHA ”编辑 (E) SEV) IR(T 帮助 (H) 
组 织 ” — Qi ” 包 合 到 库 中 v REY HERO» 3$- EM @ 
六 收藏 夫 S í |; phpweb | 
d Creative Cloud 文件 B 
Je 下 载 
mE su 
各 最 访问 的 位 置 
司库 is 
| phpweb 修改 日 期 : 2015/1/15 14:15 
| | xe 
~ A 




















图 3-12 建立 站 点 文件 夹 phpweb 

















E 


x X UU 
EI Business Catalyst S | [ SE Business Catat Shi 
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图 3-13 “管理 站 点 ” 对 话 村 


Ir 





e“ 站 点 名 称 ”: phpweb, 
e。“ 本 地 站 点 文件 夹 ”. C:\xampp\htdocs\phpweb\。 
如 图 3-14 所 示 。 
























































| 站 点 设置 对 银 phpweb =S) 
[-- BE no wc 
p| 
sso o y Dd e DANGER LARER 
》 ERE 
您 可 以 在 此 处 为 Dreamweaver 站 点 选择 本 地 文件 夹 和 名 称 。 
站 点 名 称 : [phpweb 
本 地 站 点 文件 夹 : [C:WAMPP htdocs\phpweb\ | 

















4) 单 击 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “ 添 加 服务 器 ”按钮 国 ， 打 开 “ 基 本 ” 
选项 卡 ， 进 行 如 图 3-15 所 示 的 参数 设置 。 

















































































































Lr ii = E 
站 点 I B 
LE 
版 本 控 洒 服务 器 名 称 : | phpweb 
p amsa 连接 方法: PEFEA [e] we je 
服务 器 文件 来 : [ C:wamppWtdocs 上 
Web URL: [http:// 127.0.0. 1/phpweb/ ma | | 
| 
| 
| [9 [mA 
帮助 保存 取消 
J 
图 3-15 设置 “基本 ”选项 卡 
































se“ 服务 器 名 称 ”: phpweb。 

o GERTE”: 本 地 /网 络 。 

o “IRIA”: C; \xampp \htdocs\。 

e "Web URL": http:// 127. 0. 0. 1/phpweb, 

5) 设置 后 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 ， 单 击 “ 维 护 同 
步 信 息 ” 复 选 框 ,在 “服务 器 模型 ”下 拉 列 表 项 中 选择 PHP MySQL 来 表示 是 使 用 PHP 开发 
的 网 页 ， 其 他 的 保持 默认 值 ， 如 图 3-16 所 示 。 


| 基点 设置 对 急 phpweb 






















































































=S) 
站 点 
E henze 
版 本 控制 | 远程 服务 器 
» BRE | V SEPIEEPRR ET 
C] 保存 时 自动 将 文件 上 传 到 服务 器 
C] 启用 文件 取出 功能 
区 打开 文件 之 前 取出 LNNE NM 
取出 名 称 : 
电子 邮件 地 址 : 
| 测试 服务 器 
服务 器 模型 :[ PHPwysQL r] 
帮助 了 哨 e 
ET 全 取消 



































图 3-16 设置 “高 级 ”选项 卡 


6) 单 击 “保存 ”按钮 ， 返回“ 服务 器 ”设置 对 话 框 ,再 单 击 勾 选 “ 测 试 ” 复 选 框 ， 
如 图 3-17 所 示 。 




















单 击 “保存 ”按钮 ， 则 完成 站 点 的 定义 设置 。 在 Dreamweaver CC 中 就 已 经 拥有 了 刚才 
所 设置 的 站 点 phpweb。 单 击 “ 完 成 ”按钮 ， 关闭 “管理 站 点 ”对 话 杠 ,这样 就 完成 了 
Dreamweaver CC 测试 PHP 动态 系统 网 页 的 网 站 环境 设置 。 








-0 * Dreamweaver PHPF Æ HEE 




















[ERRES phpweb 
n" 您 将 在 此 位 置 选 择 承 戟 web. 上 的 页 面 的 服务 器 。 此 对 话 框 的 设置 来 自 
BR | Internet 服务 提供 商 (ISP) & jx Web 管理 员 。 
版 本 控制 
» ”高 级 设置 








注意 :要 开始 在 Dreamweaver 站 点 上 工作 ， 您 无 需 完成 此 步 骆 。 如 果 要 和 信 接 到 Web 并 发 
布 内 面 ， 您 只 需 定义 一 个 远程 服务 悚 即 可。 


EJ P NEL: 























图 3-17 设置 “服务 器 ”参数 为 测试 


PEE 设置 数据 库 连 接 

完成 了 站 点 的 定义 后 ， 接 下 来 就 是 系统 网 站 与 数据 库 之 间 的 连接 。 网 站 与 数据 库 的 连接 
设置 如 下 。 

1) 执行 菜单 栏 “ 文 件 ”-、 “新建 ”命令 ， 在 网 站 根 目 录 下 新 建 一 个 名 为 index. php 的 


网 页 ， 输入 网 页 标题 “PHP 动态 系统 ”， 然 后 执行 菜单 “文件 ”一 “保存 ”命令 将 网 页 保 
存 ， 如 图 3-18 所 示 。 





DW 文件 (RD R86 SSV) EAD EIM) ERO SAO 站 点 (5) SOW SWH BA - ol-lel x J 
Oa | 拆 分 | 设计 ] 实时 视图 | Q. 标题 PASAR O 




















此 面板 对 于 PHP MySQL 是 不 活动 的 
。 请 选择 其 它 文档 类 型 。 


E E ENS 304 x 427v 

















Bis css 
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图 3-18 创建 空白 网 页 
2) 单 击 选择 菜单 栏 上 上 的“ 窗口” 一“ 数据库” 命令， 打开“ 数据库 ”面板 。 在 “ 数 
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据 库 ”面板 上 单 击 选择 “+” 图 标 ， 并 在 打开 的 菜单 中 选择 

"MySQL 连接 ”选项 ， 如 图 3-19 所 示 。 NIXUS —— 
3) FE "MySQL 连接 ”对 话 框 中 ， 输 入 “连接 名 称 ” 为 “|‖ Tor exse sa. 

webconn, "MySQL 服务 器 ”名 为 localhost、 “用户 名 ”为 root、 ”es. 

密码 为 空 ， 如 图 3-20a 所 示 。 选 择 所 要 建立 连接 的 数据 库 名 

称 ， 可 以 单 击 “ 选 取 ” 按 钮 ， 浏 览 MySQL 服务 器 上 的 所 有 数 ”图 3-19 选择 MySQL 连接 

据 库 。 选 择 刚 导入 的 范例 数据 库 phpweb ， 具 体 的 设置 内 容 如 图 3-20b 所 示 。 





























MySQL 连接 
连接 名 称 : webcorm 
MySQL 服务 器 : localhost 
AAE: root Cmi ) 
ge: 

数据 库 : phpweb [| 


















































图 3-20 设置 MySQL 连接 参数 
































4) 单 击 “测试 ”按钮 ， 测 试 与 MySQL 数据 库 的 连接 是 否 正确 ， 
如 果 正 确 ， 则 出 一 个 消息 框 ， 如 图 3-21 所 示 这 表示 数据 库 连 接 设置 
成 功 。 

单 击 “ 确 定 ” 按 钮 ， 则 返回 编辑 页 面 ， 在 “数据 库 ” 面 板 中 则 
显示 绑 定 过 来 的 数据 库 ， 如 图 3-22 所 示 。 

在 建立 完成 MySQL 连接 后 ， 在 “文件 夹 ”面板 中 会 看 到 Dream- ”图 3-21 设置 成 功 
waver 自动 建立 了 Connections 文件 夹 ， 在 该 文件 夹 下 有 一 个 与 前 面 所 建立 的 MySQL 连接 名 
称 相同 的 文件 ， 如 图 3-23 所 示 。 

MRE E EEDA s l MM- 一 | 
| 本 地 视图 v 


(C) phpweb 
$Je|oewae|m 
大 






































Qa age (tinyint 4) 
Hg ID Gint 11 必需 的 ) Pe Ir eg 
M, nane (varchar 20) T) index php 1KB PHP 文件 
i Rh, Result (varchar 20) 
A 视图 
dw ”预存 过 程 








Q az 
3-2 Skid 图 3-23 自动 生成 的 文件 











Connections 文件 夹 是 Dreamweaver 用 来 存放 MySQL 连接 设置 文件 的 文件 来。 打开 该 文 
件 并 使 用 “代码 ”视图 ， 可 以 看 到 连接 数据 库 的 设置 ， 如 图 3-24 所 示 。 
在 这 个 文件 中 定义 了 与 MySQL 服务 需 的 连接 (mysql_pconnect 图 数 ) ， 包 括 以 下 内 容 。 
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Dw zP) $869 SEV) EAM 修改 (M) ”格式 (0) SAO 站 点 (S) SOW SH) RB. (Dou Elija 
OB] 拆 分 | 设计 | 实时 视图 Qo ni 
M X phpweb - CAxampp\htdocs\phpweb\Connections\webconn.php (Erret JE = 
*php 
EE 2 FileNane=" »)o|*t:tse| 
3X s 
EE] 4 # HTTP="true cg - phpreb (Ci... 
er 5  $hostname webconn = "localhost"; 日 onnections 
Et a 
e 6  $database webconn = "phpweb"; "S webconn. php 1 了 
7 $username_webconn = "root"; 
8  $password webconn = "" web 
9  $webconn = mysql pconnect(S$hostname webconn, $username webconn, $password webconn) or "ho add php AKB 
trigger error(mysql error(),E USER ERROR); Tho del php AKB 
2> =, detail. php 3KB 
=, index.php SKB 
=, update. php 4KB 
(<> mm] | 格式 @) (x 1 
Bh. css mi) 无 ~ BHEO 
< [EL 上 
Q 工 个 本 地 项 目 被 选中 ,总 [ 目 志 二 




















图 3-24 数据 库 连 接 设 置 


e $hostname: MySQL 服务 需 的 地 址 。 

e $database: 连接 数据 库 的 名 称 。 

e $username: 用 户 名 称 。 

e $password: 用 户 密码 。 

定义 的 值 与 在 前 面 图 形 界面 所 设置 的 值 是 对 应 的 ， 然 后 利用 函数 mysql. |. connect 与 数据 
库 连 接 。 连 接 后 才能 对 数据 库 进行 查询 、 新 增 、 修 改 或 删除 的 操作 。 

如 果 在 网 站 制作 完成 后 将 文件 上 传 至 网 络 上 的 主机 空间 时 ， 发 现 网 络 上 的 MySQL 服务 
器 访问 的 用 户 名 、 密 码 等 方面 与 本 机 设置 有 所 不 同 ， 可 以 直接 修改 位 于 Connections 文件 夹 
下 的 webconn. php 文件 。 





检查 数据 库 记 录 





本 小 节 将 介绍 在 Dreamweaver 中 与 检查 数据 库 记 录 相 关 的 “服务 器 行为 ”， 主 要 包括 记 
录 集 、 捕 和 记录、 更 新 记录 、 重 复 区 域 、 显 示 区 域 和 记录 集 分 页 等 常用 的 动态 服务 顺 行 为 。 


sur 创建 记录 集 


在 每 个 需要 查看 数据 库 记 录 的 页 面 中 丝 须 为 其 建立 一 个 “记录 集 (查询 )”， 从 而 可 以 
让 Dreamweaver 知道 ， 目 前 这 个 网 页 中 所 需要 的 是 数据 库 中 的 哪些 数据 。 即 便 需 要 的 内 容 一 
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态 网 站 开发 从 入 门 到 精通 


样 ， 在 不 同 网 页 也 需要 单独 建立 。 同 一 个 数据 库 只 需 建 立 一 次 MySQL 连接 ,但 可 以 为 同一 
个 MySQL 数据 库 连 接 建 立 多 个 “记录 集 ”， 配 合 筛选 的 功能 ， 达 到 某 个 记录 集 只 包含 数据 
库 中 符合 某 些 条 件 的 记录 。 

打开 index. php 文件 后 ， 选 择 菜 单 栏 上 的 “应 用 程序 ” 
一 “ 绑 定 ”面板 (如 果 第 一 次 运行 忘 了 安装 CC 版 的 扩展 
功能 ， 请 先 安装 扩展 后 即 可 以 正常 显示 所 有 的 面板 ) ， 选 
择 “ 记 录 集 (查询 )” 便 可 以 建立 记录 集 。“ 应 用 程序 ” 
一 “ 绑 定 ”面板 中 的 “记录 集 (查询 )” 与 “服务 器 行 
为 ”面板 中 的 “记录 集 ” 是 相同 的 。 如 图 3-25 所 示 。 Spry BER 

按说 明 设置 各 项 如 图 3-26 所 示 ， 然 后 可 以 单 击 “ 测 | 一 
iX" TES, Dreamweaver 会 显示 目前 设置 所 返回 的 记录 集 
内 所 有 记录 。 字 段 的 功能 说 明 如 表 3-4 所 示 。 


表 3-4 字段 与 功能 说 明 


























































































































* E 说 —Hj 
名 称 一 般 用 Recordset ( 记录 集 ) 的 缩写 rs 作为 开头 
连接 选择 所 建立 记录 集 的 数据 库 是 在 哪个 MySQL 连接 
列 此 处 显现 该 数据 库 连 接 中 所 有 的 数据 表 ， 以 及 所 选 数据 表 内 所 有 字段 
筛选 是 否 依据 条 件 筛选 记录 
排序 是 否 家 照 某 个 段 值 进行 排序 。 比 如 ， 在 新 闻 系 统 中 需要 把 新 的 新 闻 放 到 前 面 位 置 ， 就 可 
以 使 用 排序 的 功能 








“记录 集 (查询 )” 使 用 到 的 就 是 SELECT 语句 ， 因 为 查询 出 来 的 结果 可 能 会 有 很 多 条 ， 
所 以 称 为 “记录 和 集 ( 合 )”， 而 “筛选 ”部 分 则 对 应 WHERE 子 句 。 




















记录 条 [= 
名 称 : ES | 确定 | 
iti [rice JE 
At websgl -| ( mit ] 





T (mm) 
Result 


VRL 参数 


排序 : 无 vj 升序 












































到 3-26 ”设置 “记录 集 ” 





单 击 “ 测 试 ”按钮 后 ， 可 以 看 到 返回 的 记录 。 因 为 没有 做 任何 筛选 的 处 理 ， 所 以 会 返 
回 完整 的 所 有 记录 ， 如 图 3-27 所 示 。 

可 以 单 击 “ 高 级 ”按钮 查看 该 SQL 语句 。 可 以 看 到 ，Dreamweaver 提供 了 一 个 基本 的 图 
形 界面 ， 实 际 上 它 会 生成 相应 的 程序 代码 。 在 “高 级 ”窗口 中 可 以 看 到 相应 的 SQL 语句 ， 
如 图 3-28 所 示 ， 另 外 还 提供 加 入 变量 、 修 改 SQL 语句 的 功能 ， 用 以 满足 使 用 简单 图 形 界面 
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f — = -—— E! 
测试 sQl 措 令 iJ 
记录 ID nam age Result 
1 1 testi 21 100 
2 2 test? 22 98 
3 3 test3 22 86 
4 4 testá 21 89 
5 5 test5 23 74 
6 6 testB 21 66 
T T testT 22 95 
8 8 testB 23 8T 
8 9 testa 24 69 
10 10 test10 23 68 
nu 12 testll 10 58 
| | 
| 
[ m D | 
[ 前 25 个 @) T254-00 ] 
© A 

















K 3-27 单 击 “测试 ”按钮 浏览 记录 集 


设置 无 法 满足 的 情况 。 
在 记录 集 建 立 完毕 后 ， 可 以 在 “应 用 程序 ”一 “ 绑 定 ”面板 中 查看 到 目前 页 面 里 的 所 
有 记录 集 ， 以 及 各 记录 集中 的 字段 ， 双 击 记 录 集 可 以 重新 打开 图 3-29 所 示 的 设置 窗口 。 
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名 称 : ED 
连接 : [webeonn -| EX 
SQL: SELECT * " 
FROM websql 
** zl 
名 称 : 
类 型 : 
FRAIS: 
运行 值 : 
CRE 
| menjena X EE 
ER aA 
f. Miri 
| 
P pe 二 二 — ESI 
图 3-28 “高 级 ”记录 集 窗 口 图 3-29 绑 定 的 记录 集 效 果 











建立 记录 集 与 直接 写 SELECT 语句 是 相同 的 ， 将 页 面 切换 到 “代码 ”视图 ， 如 图 3-30a 
所 示 。 其 中 第 1 行 的 require, once 函数 是 用 来 引入 文件 的 ， 即 前 面 介 绍 过 的 webconn. php. 
TE Dreamweaver 中 ， 若是 已 经 定义 好 数据 库 连 接 ， 那么 在 其 他 建立 记录 集 、 更 新 记录 、 插 入 
记录 、 删 除 记录 的 页 面 中 ， 这 个 连接 设置 文件 就 会 在 页 面 的 最 前 面 被 引入 (这 就 是 为 什么 
在 同一 个 站 点 中 内 需要 定义 一 次 MySQL 数据 库 连接 ) ， 因 为 该 文件 中 所 包括 的 与 数据 库 连接 
相关 的 设置 需要 被 使 用 。 

其 程序 具体 分 析 如 图 3-30b 所 示 。 

1) 第 34 行 引用 了 webconn. php 内 的 设置 (变量 $datebase_webconn 与 $webconn 被 定义 
在 这 个 文件 中 ) 来 选择 数据 库 (mysql_select_db( ) ) ， 随 后 的 mysql. query C) 所 作用 的 都 是 此 
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Dw xékF) #0  EFE(V) EA(D 修改 (M) 格式 (0) 命令 (C) HAO SOM 帮助 (H) | 
indexphp x — " mE | " — || phpweb -Cxampp\htdocs\phpweb\ind 
webconn. php m 
CREJ 拆 分 | | 设计 v) H. 
n I] <?php require once('Connections/webconn.php'); ?> ^ 
7| 2 <?php 
$| 3 if (!function_exists("GetSQLVaLueString")) { 
z 4 function GetSQLValueString(StheValue, $theType, $theDefinedValue = "", $theNotDefinedValue = 
nn 
gall ) 
< Jí 
6 if (PHP_VERSION < 6) { 
得 | 7 $theValue = get magic quotes gpc() ? stripslashes(StheValue) : $theValue; 
EM g l 
[-] 9 
p 10 S$theValue = function exists("mysql real escape string") ? mysql real escape string(StheValue 
) : mysql escape string($theValue); 
=j 11 
回 12 switch ($theType) { 
Em 13 case "text": 
Q 14 $theValue = ($theValue != "") ? "'" , $theValue . "'" : "NULL"; 
B 15 break; 
(a 16 case "long": 
of 17 case "int": 

18 $theValue = ($theValue != "") ? intval(StheValue) : "NULL"; a, 
-E i : D 
body .ca Lt 9. 

Et 

om] T) | 无 - 3 cs = P te 2 Ham 

Ba css mn 无 ~ WO "Og Bio * 

文档 标题 THE 动态 系统 页 面 属性 ... 列表 项 目 . .. 
a) 

Dw 交 伯 (6 #9 EEEQV) 插入 (1 BUM) 格式 (0) 命令 (C) 站 点 (S) 窗口 (W) 帮助 (H) | | Es -| E 0 1E x 
index.php* X phpweb - C: P 
webconn. php 












* 文档 类 型 : PHP 
记录 集 Rsd) 











拆 分 





设计 实时 视图 | 




















B 29 H ^ 
z| 30 return $theValue; 
* 31 i 
Ey 2 1 
33 





Imysql select db($database webconn, $webconn); 
S$query Rsdh "SELECT * FROM websql"; 

sRsdb = mysql query($query Rsdb, $webconn) or die(mysql error()); 
$row Rsdb = mysql fetch assoc($Rsdb); 
jStotalRows Rsdb = mysql num rows ($Rsdb); 
7> 

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 

"http: //www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"> 

«html xmlns-"http://www.w3.org/1999/xhtml"» 

<head> 

«meta http-equiv-"Content-Type" content-"text/html; charset-utf-8" /» 
<title>PHP 动 态 系统 </title> 

<style type="text/css"> 

.aline center { 





























<? 服务 器 置 标 
: if (Ifunction exists("GetSQLVelueString")) [ 

function GetSülYslueString(ftheValue, $theType, $theDefinedValue = "", $theHotDefinedYslue = "") 
i 






if (PHP VERSION € 8) [ 
$theValue = get magic quotes gpe() ? siripslashes(jtheValue) : $theValue; 





















b) 
图 3-30 自动 生成 的 代码 视图 
a) 代码 视图 1 至 18 行 b) 代码 视图 29 至 46 行 











2) 第 35 行 定 义 了 查询 数据 库 的 SQL 语句 。 
3) 第 36 行使 用 第 35 行 所 定义 的 SQL 语句 对 数据 库 执行 查询 操作 (mysql. query () ) ， 





第 Dreamweaver+PHP 开 发 基础 








此 时 返回 结果 是 资源 标识 符 ， 还 不 能 被 使 用 。 
4) 第 37 行将 前 面 查询 的 结果 以 关系 型 数组 的 形式 (mysql_fetch_assoc( ) ) 传 至 变量 
$row_Rsdb， 然 后 就 可 以 使 用 $row_ 记 录 集 名 称 [ 字段 名 称 ] 来 取得 记录 集 字 段 值 。 
5) 第 38 列 取得 查询 结果 的 记录 条 数 (nsqL_num_rmws() ) ， 并 赋 给 变量 $tolalRows_ Rsdb。 — 人) 
6) 最 后 mysql_free_result( ) 释放 查询 结果 与 占用 的 内 存 资源 。 
上 面 是 Dreamweaver 连接 数据 库 并 执行 查询 的 标准 步骤， 在 mysql. query ($query_Rsdb， 
$webconn) or die (mysql error( ) ) 的 部 分 ,大 or 前 面 语句 出 现 错误 或 失败 ， 就 执行 or 后 面 
的 程序 。 所 以 若 数据 库 查 询 失 败 的 时 候 就 会 产生 错误 信息 ， 并 终止 程序 的 运行 。 
在 一 般 PHP 程序 中 ， 典 型 的 连接 与 查询 程序 类 似 下 面 的 例子 。 


mysql_select_db( $database webconn, $webconn); 

$query_Rsdb = "SELECT * FROM websql" ; 

$Rsdb = mysql query( $query Rsdb, $webconn) or die( mysql error( ) ) ; 
$row Rsdb = mysql fetch assoc( $Rsdb); 

$totalRows Rsdb = mysql num rows( $Rsdb ) ; 

mysql free result( $Rsdb) ; 


可 能 会 觉得 Dreamweaver 产生 出 来 的 程序 代码 比较 复杂 ， 这 是 因为 Dreamweaver 建立 的 
记录 集 需 要 搭配 很 多 服务 器 行为 来 使 用 。 


时 示 记 录 功 能 


接着 要 将 记录 集 内 的 记录 ( 即 数 据 库 中 的 数据 ) 直接 显示 到 网 页 上 ， 实 现 的 步 又 如 下 。 
1) 在 “文件 ”面板 中 打开 index. php， 在 网 页 中 制作 一 个 如 图 3-31 所 示 的 2 x4 表格 ， 
然后 在 “应 用 程序 ”一 “ 绑 定 ”面板 ， 选 择 所 需 的 字段 并 拖 动 到 表格 中 。 
Dw XÐ A6 EQ) 插入 由 修改 (M) 格式 (0) SMO 站 点 ($) SOW SAH 


EASP webconn. php 
[oue |ia [GRE] 实时 视图 | 











































Q. 标题 masa | 4f 




















PHP 动 态 系统 
序号 姓名 年 龄 
(Rsdb.ID) (Rsdb.name] (Rsdb.age) (Rsdb.Result) 
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图 3-31 2p EE 

2) 在 使 用 鼠标 拖 动 字 段 至 页 面 上 放 开 后 ， 会 出 现 | Rsdb. name] 的 字样 ， 其 中 Rsdb 为 
记录 集 名 称 ，name 为 字段 名 称 。 将 序号 、 姓 名 、 年 龄 、 成 绩 4 个 字段 分 别 拖 至 相应 的 单元 
kE, Hah senmm 按钮。 














视图 所 呈现 的 效果 与 使 用 浏览 器 打开 网 页 一 样 ， 原 本 仅 显 示 | 记录 集 名 称 . 字段 名 称 | 
的 部 分 将 会 显示 出 记录 集 内 的 记录 ， 如 图 3-32 所 示 。 
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代码 | 拆 分 | 设计 ] 实时 视图 | | 实时 代码 | 检查 O, m > O http://127.0.0.1/phpweb/index. php 
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3-32 ”实时 视图 效果 


3) 再 单 击 一 次 [CS 下 按钮 ， 将 页 面 切换 到 LE 视图 ， 可 以 看 | 记录 集 名 称 . 字段 名 
称 } 部 分 的 代码 ， 在 该 程序 代码 中 使 用 echo 来 输出 字段 值 ， 如 图 3-33 所 示 。 























Dw xb #85 SEV) ÆAD BEM) 格式 (0) 命令 (Q HASO SOW 帮助 (H) HA. (o) E 
vene x phpweb - CAXAMPPAhtdocsiphpweblindex.php | 
webconn. php 
i CERT 拆 分 | 设计 XM OQ. 5 DEDE m a E e i 
j "m Er J a ud 
66 <td> 年 龄 </td> ^| ”动态 文本 (Rsdb.ID) 
67 <td> 成 绩 </td> 动态 文本 (Rsdb name) 


动态 文本 (Rsdb.age) 
动态 文本 (Rsdb. Result) 









<td><?php echo $row Rsdb['ID']; ?»«/td» 
«td»«?php echo $row Rsdb['name']; ?»«/td» 
<td><?php echo $row Rsdb['age']; ?»«/td» 
<td><?php echo $row Rsdb['Result']; ?»«/td» 
74 </tr> 

75 </table> 

76 <hr /> 

77 <p>&nbsp;</p> 

78 </body> 







</html> 
80 <?php 
81 mysql free result($Rsdb); 
82 ?> 1 
83 
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3-33 ”代码 视图 效果 


SERES 重复 区 域 功能 


现在 只 能 看 到 记录 集中 的 第 1 条 记录 ， 那 后 面 的 记录 如 何 显示 出 来 呢 ?Dreamweaver f 








Dreamweaver+PHP 开 发 基础 





供 了 “重复 区 域 ”及 “记录 集 分 页 ”的 功能 ， 只 需要 妃 
选取 需要 重复 的 部 分 ， 即 表格 中 的 第 2 行 ， 如 图 3- 
板 中 单 击 “ + ”按钮 ， 从 弹出 的 下 拉 菜 单 中 选择 “重复 区 


标 拖 动 ， 就 可 以 实现 这 个 功能 。 
34 所 示 ， 然 后 在 “服务 器 行为 ” 面 
D dq, 3-35 所 示 。 
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了 PHP 动态 系统 
—] 600» | 用 户 身份 验证 
- < > < XSLT 转换 
序号 姓名 Fit 成 绩 编辑 服务 器 行为. 
(Rsdb.ID) (Rsdb.name) (Rsdb.age) (Rsdb.Result) 新 建 服务 器 行为. . 

















获取 更 多 服务 器 行为 " 





图 3-34 选取 表格 第 2 行 


之 所 以 要 确认 选取 的 标签 为 <r> ， 是 因为 重复 区 域 会 使 用 do… 


的 范围 。 而 需要 重复 的 仅 是 第 2 íT 


了 的 表格 ， 在 HTML 中 表格 的 行 是 使 用 <t > 标签 。 











图 3-35 选择 “重复 区 域 ”命令 


while 循环 包围 所 作用 
确认 选 


















































取 的 标签 正确 ， 执 行 时 才 不 会 发 生 错误 。 LI ~ wu 
此 时 会 弹出 一 个 窗口 ， 如 图 3-36 所 示 ， 要 求 选 Wa ER 
择 要 重复 记录 的 记录 和 集 ， 以 及 需要 重复 几 条 记录 或 显 za E MER 
示 全 部 记录 。 同 样 地 选择 [实时 视图 ]， 这 时 就 可 以 看 到 
原来 只 有 两 行 的 表格 已 经 增长 到 6 行 ， 如 图 3-37 所 
示 ， 而 记录 和 集 内 的 前 5 4 条 记录 都 已 显示 在 页 面 上 。 图 3-36 设置 重复 区 域 
Dw 文人 (9 S80 ZEV ÆA 修 改 (M) ERO 命令 (0) HASO SOW WAH) ol-lelx] 


estet x 
webconn. php 





压缩 - 















ORB iia [设计 | 实时 视图 ] | 





实时 代码 dE Qu € > O http://127.0.0.1/phpweb/inde 
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3-37 实时 预览 效果 
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所 有 页 面 上 的 “服务 器 行为 ”都 会 被 列 在 “ 窗 。 EBP 于 
口 ”一 “服务 器 行为 ”面板 的 清单 中 ， 在 本 例 中 ， | x - eea ne 

选择 重复 5 条 记录 。 若 想 要 修改 服务 器 行为 的 设置 ， | EXESSS. 
则 可 以 通过 双击 该 服务 器 行为 来 进行 ， 如 图 3-38 | max ut mo 
所 示 。 eua ue 


将 页 面 切换 到 “代码 ”视图 ， 在 套用 了 “重复 
区 域 ”服务 器 行 为 后 ， 在 程序 代码 当中 的 变化 便 是 
这 行 单元 格 的 上 下 被 do…while 循环 包围 了 ， 而 重复 
的 条 件 为 第 87 行 语句 如 图 3-39 所 示 ， 用 这 样 的 循 
环 可 以 达到 将 记录 集中 的 记录 全 部 输出 才 停 止 循环 。 




















图 3-38 ”服务 器 行为 面板 














Dw zÐ) $569 SEV) EAM 修改 (M) ”格式 (0) SAO ”站 点 (S$) SOW ”帮助 (H) Hm. © -lol x 


phpweb - C\XAMPP\htdocs’ 





* - 文档 类 型 : PHP 
记录 集 (Rsdb) 

重复 区 域 Rsa) 
str» 动态 文本 (Rsdb. ID) 
d ? 动态 文本 (Rsdb. name) 
St 动态 文本 (Rsdb. age) 
动态 文本 (Rsdb.Result) 





拆 分 | 设计 xg Q. du Denk Je 








<tr> 
<td><a href="detail.php"><?php echo $row Rsdb['ID']; ?></a></td> 
<td><?php echo $row_Rsdb['name']; ?»«/td» 
<td><?php echo $row Rsdb['age']; ?»«/td» 
<td><?php echo $row Rsdb['Result']; ?»«/td» 
</tr> 
<?php } while ($row_Rsdb = mysql_fetch_assoc($Rsdb)); E3 
</table> 
<table width="600" border="1" align="center" cellpadding="1" cellspacing="1"> 
<tr> 
«td width="143"> [第 一 页 ] </td> 


width="143"> [下 一 页 ] «/td» 
«td width="148"> [最 后 一 页 ] </td> 
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cm opa č Eo 



























































图 3-39 ”循环 语句 








在 建立 记录 集 时 就 知道 有 10 条 记录 都 在 记录 集中 ， 可 是 在 这 里 怎么 显示 了 5 条 记录 呢 ? 
回头 来 检查 下 代码 ， 如 图 3-40a 所 示 。 
发 现 数据 库 查 询 语 名 被 改写 过 ， 在 第 42 行 变量 $query_Rsdb 所 用 的 SQL 语句 是 以 前 介 
绍 过 的 ， 但 在 第 43 行 该 变量 会 放 到 字符 串 的 第 一 个 %s 位 置 处 ， 如 下 : 
$query limit Rsdb = sprintf("%s LIMIT %d, %d", $query_Rsdb, $startRow_Rsdb, $maxRows_ 
Rsdb) ; 


由 上 述 代 码 可 知 ,%s 表示 字符 串 ， 后 面 两 个 % d 表示 数值 ， 所 要 代入 的 值 是 $startRow_ 
Rsdb 与 $maxRows_Rsdb。 $maxRows_Rsdb 这 个 变量 值 与 前 面 在 重复 区 域 所 选择 的 重复 5 条 
记录 是 同步 的 ， 可 以 看 到 第 34 行 定 义 了 这 个 变量 的 值 ， 如 图 3-40b 所 示 。 


$maxRows_Rsdb = 5; 
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SOW 帮助 (H) | 
phpweb - CAXAMPP\htdocs\phpweb\index.php 



































$startRow Rsdb - $pageNum Rsdb * $maxRows Rsdb; 动态 文本 Medb ; 
动态 sdb. name 


动态 
mysql_select_db($database_webconn, $webconn); e Pekin 


"SELECT * FROM websql"; 
$query Rsdb, $startRow Rsdb, 


yysql query($query limit Rsdb, $webconn) or die(mysql error()); 
$row Rsdb = mysql fetch assoc($Rsdb); 


if (isset($ GET['totalRows Rsdb'])) { 
$totalRows Rsdb = $ GET['totalRows Rsdb']; 
} else [ 
$all Rsdb = mysql query($query Rsdb); 
$totalRows Rsdb = mysql num rows($all Rsdb); 
H 
$totalPages Rsdb = ceil(StotalRows Rsdb/$maxRows Rsdb)-1; 
?> 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 















































«2 MEEN 
* if (Ifunction exists("GetSQLValueString")) [ 
TREE GetSülValueString($theValue, $theType, $ihelefinedValue = "", $iheNotDefinedValue = "") 
if (PHP VERSION <6) { 
$theValue = get magic quotes zpc() ? zstripslashes($theValue) : $theValue; 
a) 
Dw 2P 850 mE(V) 插入 (] 修改 (M) 格式 (0) SA0 HAOS SOW 者 二 HW | | 新 . EH eE X | 
indexphp x phpweb - Cxampp\htdocs\phpweb\index php 
[ISBN webconn.php ar 
j sk m) +. 
30 return $theValue; ^ 
BI 
H 


|t n 
ww ww 
pd 


E 


$currentPage - $, SERVER["PHP SELF"]; 








< 
È 36  $maxRows Rsdb = 5; 
(I| 37  $pageNum Rsdb = 6; 


3 if (isset($ GET['pageNum Rsdb'])) { 

B 3 $pageNum_Rsdb = $ GET['pageNum Rsdb']; 

40 ] 

$startRow Rsdb = $pageNum Rsdb * $maxRows, Rsdb; 





44  $query Rsdb = "SELECT * FROM websql"; 

45  $query limit Rsdb = sprintf("%s LIMIT Xd, %d", Squery Rsdb, $startRow Rsdb, $maxRows Rsdb); 
46  $Rsdb = mysql query($query limit Rsdb, $webconn) or die(mysql error()); 

47  $row Rsdb = mysql fetch assoc(SRsdb); 





回 43 mysql select db($database webconn, $webconn); 
四 | 
E 
Y 








<7 MBRET 


if (lfunction exists ("GetSQlValueString")) [ 
function GetSüDYslusString(PtheValue, fthelype, $theDefinedValus = ", $iheNotDefinedVslue = "*) 


i£ (PHP VERSION <6) i 
$theValue = get magic quotes gpcí) ? stripzlashes(ftheValue) : $theValue; 

















b) 
图 3-40 ”代码 窗口 
a) 代码 窗口 38 至 55 行 b) 代码 窗口 30 行 至 48 íT 
可 以 知道 ，Dreamweaver 使 用 了 一 堆 变 量 来 记录 在 图 形 界面 中 所 选择 和 设置 的 值 ， 然 后 
使 用 LIMIT 子 句 来 做 到 一 次 显示 指定 条 数 的 记录 。 
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记录 集 分 页 功能 











上 一 节 已 经 浏览 到 记录 集中 的 第 1 ~ 第 5 条 记录 ， 那 么 剩 下 的 记录 如 何 显示 ? 下 面 就 介 
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绍 记录 集 分 页 功能 的 实现 方法 。 

1) 在 页 面 下 方 加 上 1x4 的 表格 ， 接 着 在 单元 格 中 分 别 输入 [第 一 页 ] 、[ 前 一 页 ]、[ 下 一 
Ji. 、[ 最 后 一 页 ] 等 文字 。 使 用 鼠标 选取 [ 第 一 页 ] ， 然 后 在 “服务 器 行为 ”面板 单 击 “+” 
按钮 ， 从 弹出 的 下 拉 荣 单 中 选择 “记录 集 分 页 ”一 “ 移 至 第 一 页 ”命令 ， 如 图 3-41 所 示 。 


用 

















Dw 2P $86 ZEV) EA) 修改 (M) 格式 (0) 命令 (Q HAS) 
indexphp* x phpweb 
webconn. php Rs 
| (eB [iio | 设计 ] 实时 视图 O. — E Dues || st 一 二 


窗口 (W) ”帮助 (H) HA. © 


tdocs\phpweb\index php 





































PHP 动 态 系统 
姓名 FR 成 绩 

















{Rsdb.age} 
B-A] B-A] IT 下 一 页 ] [RER 














EB E EH 726x353» 























图 3-41 设置 为 “ 移 至 第 一 页 ” 





2) 在 弹出 的 对 话 框 中 ， 选 择 记 录 集 , 确认 链 [sem ” C = 























接 所 选 的 范围 ， 如 图 3-42 所 示 。 nr OES E z] 
3) 分 别 为 [前 一 页 ] 、[ 下 一 页 ] 、[ 最 后 一 页 ] | mm m 


套用 “ 移 至 前 一 页 ”、“ 移 至 下 一 页 ”、“ 移 至 最 后 
一 页 ”的 服务 器 行为 。 然 后 按键 盘 上 的 《FI12》 
键 ， 在 浏览 器 中 检查 输出 结果 ， 如 图 3-43 所 示 。 ”图 3_42 设置 “ 移 至 第 一 页 ”对 话 框 

在 页 面 中 试 试 刚刚 完成 的 导航 条 ， 可 以 注意 到 网 址 

后 面 加 了 pageNum, Rsdb 5 totalRows Rsdb 两 个 URL 变量 ,被 用 来 在 分 页 浏览 时 与 重复 区 域 
服务 器 行为 相 搭配 。 






















































































































































































kela) 
y G http;//127.0.0.1/phpweb/index.php?pageNum Rsdb-i&totalRows Rsdb-: O ~ B © X | (D vy t9 
您 pHp 动 态 系统 x unn 
PHP 动 态 系统 

| FE kz E Dj 

6 testó 21 66 

7 test7 22 95 
| 8 tests 23 87 

9 test9 24 69 
[| 109 | test10 23 68 
| [$—H3] [前 一 页 ] [ 工 一 页 ] [最 后 一 页 ] 















































3-43 ”分 页 浏览 效果 
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也 可 以 在 Dreamweaver KA pA "df A" — "Gorg" o “WEED” > “Ww 
录 集 导航 条 ”命令 ， 来 快速 地 插入 本 范例 中 所 建立 的 记录 和 集 导 航 条 。 


3.3.5 显示 记录 计数 


di 
在 页 面 上 方 输入 “ 共 * 笔 记录， 目前 查看 第 * 笔 ~ 第 * 笔 ”， 建 立 起 记录 集 导 航 条 ， 以 
便 让 用 户 了 解 有 多 少 页 记录 和 当前 正在 浏览 的 页 码 。 
1) 将 插入 点 置 于 “共有 ”和 “笔记 录 ” 之 间 ， 选 择 “ 服 务 器 行为 ”面板 , 单 击 “+” 
按钮 ， 从 弹出 的 下 拉 菜 单 中 选择 “显示 记录 计数 ”一 “显示 总 记录 数 ”， 然 后 同样 要 选择 记 
录 集 ， 如 图 3-44a, 3-44b 所 示 。 








































































































ED vebeonn. php ii " 
| «Bie [5x] 天 纲要 O, d nemis Ts] ERR 
PHP 动态 系统 重复 区 域 
RED 
共有 加 笔记 录 ， 目 前 查看 第 * 笔 至 第 "和 E D 
pen ER pa er uM 
Rsdb ID} {Rsdb name} [Rsdb age) [Rami  Bremones acid 
Em Ee me 性 -一 CNES 
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geom 
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a) 





图 3-44 显示 总 记录 数 





2) 按 同 样 的 方式 ， 将 搬入 点 置 于 相应 位 置 ， 依 序 加 入 “显示 起 始 记录 编号 ”及 “显示 
结束 记录 编号 ”， 完 成 后 页 面 如 图 3-45 所 示 。 





Dw XÐ %80 ERE) ÆA 修改 (M) 格式 (0) 命令 (CQ) AO SOW SH) BA. (Dil ELI X 

indexphp* x phpweb - CAXAMPP\htdocs\phpweb\index.php 

webconn. php 

| 代码 | 拆 分 [ 设计 ] sem Q. 标题 nemes o O 
PHP 动 态 系统 










*€ - XH: n 


记录 集 (Rsdb) 
显示 总 记录 数 (Rsdb) 
显示 起 始 记录 编号 Rsd) 
显示 结束 记录 编号 Rsd) 
重复 区 域 (Rsdb) 

动态 文本 (Rsdb. ID) 
动态 文本 (Rsdb. name) 
动态 文本 (Rsdb. age) 
动态 文本 (Rsdb. Result) 
移 至 第 一 页 (Rsdb) 
移 至 前 一 页 (Rsdb) 
移 至 下 一 页 (Rsdb) 
移 至 最 后 一 页 (Rsdb) 
























共有 很 sdb.TotalRecords} 笔记 录 ， 目 前 查看 第 {Rsdb.FirstRecord} 笔 至 第 {RsdbLastRecd 来 能 
时 姓名 年 龄 "d 
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3-45 加 入 统计 记录 


完成 后 ， 当 浏览 该 网 页 时 ， 便 会 出 现 当 前 共有 几 笔 记录 ， 以 及 目前 查看 的 是 第 几 笔 ~ 第 
几 笔 的 提示 文字 ， 如 图 3-46 所 示 。 








动态 网 站 开发 从 入 门 到 精通 


































































































— [EI 
Q http;//127.0.0.1/phpweb/index.php?pageNum Rsdb-1&totalRows Rsdb-: O ~ B © X |. 45 ve $93 
Ep x a 
PHP 动 态 系统 [3 
序号 姓名 年 龄 a 成 绩 
6 test6 21 66 
test7 22 95 Jl 
8 test8 23 87 " 
9 test9 24 69 
10 test10 23 68 
第 一 页 前 一 页 一 页 最 后 一 页 
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图 3-46 建立 导航 条 效果 


也 可 以 在 Dreamweaver 菜单 中 选择 “插入 ”一 “数据 对 象 ”一 “显示 记录 计数 ”一 
“记录 集 导 航 状 态 ” 来 快速 地 插 人 本 例 中 所 建立 的 记录 集 导 航 条 。 


SES 显示 区 域 功能 


在 第 一 页 上 的 [第 一 页 ] 与 [前 一 页 ] 的 文字 链接 是 没有 意义 的 。 下 面 我 们 就 来 处 理 这 个 
可 题 ， 如 果 不 是 第 一 页 时 ， 显示 [第 一 页 ] 与 | 前 一 页 ]; 如 果 不 是 最 后 一 页 时 ,显示 [ 下 一 
页 ] 与 [最 后 一 页 ] 。 

实现 该 功能 的 步 又 如 下 。 

1) 选择 [第 一 页 ]， 在 “服务 器 行为 ”面板 中 单 击 “ +” 按钮 ， 从 弹出 的 下 拉 菜 单 中 
选择 “显示 区 域 ” 一 “如 果 不 是 第 一 页 则 显示 ”命令 ， deis 47a 所 示 。 打 开 “ 如 果 不 是 
第 一 页 则 显示 ”对 话 框 ， 选 择 “ 记 录 集 ”Rsdb， 再 单 击 “ 确 定 ” 按 钮 ， 如 图 3-47b Bro, 
然后 为 [ 前 一 页 ] 也 做 同样 的 设置 ， 即 可 完成 设置 。 
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HA (Rsdb.TotalRecords) 笔记 录 ， 目 前 查看 第 {Rsdb FirstRecord} 笔 至 
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如 果 是 最 后 一 页 则 显示 
如 果 不 是 景 后 一 页 则 显示 
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图 3-47 设置 “如 果 不 是 第 一 页 则 显示 ” 





2) 选取 [下 一 页 ] 链 接 文字 ， 在 “服务 器 行为 ”面板 中 单 击 “+ ”按钮 ， 从 弹出 的 下 
拉 荣 单 中 选择 “显示 区 域 ”一 “如 果 不 是 最 后 一 页 则 显示 ”命令 ， mgs- 48 所 示 。 然 后 为 
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[最 后 一 页 ] 也 做 同样 的 设置 。 








Dw E) #86 SEV) EAM 修改 (M) 格式 (0) 命令 (Q HAS SOW 帮助 (H) 















































indexphp* x phpweb - CAXAMPP htdocs phpweblindex php 
webconn. php 
| Bia [设计 | 实时 视图 Q. 标题 : Fi 动态 系统 — 5 MW. 
PHP 动 态 系统 
共有 人 Rsdb .TotalRecords} 笔记 录 ， 目 前 查看 第 {Rsdb FirstRecord} 笔 至 如 果 记 录 集 为 空 则 显示 EE 5 
BE RE r3 (id ^ 如 果 记 录 集 不 为 裤 则 呈 示 显示 记录 计数 
[ 如 果 是 第 一 页 则 显示 动态 文本 
METEN FN: CREE 
[| ”如果 是 最 后 一 页 则 显示 mom 
如 果 不 是 最 后 一 页 则 显示 — 
动态 表单 元 素 » 
用 户 身份 验证 , 
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图 3-48 设置 “如 果 不 是 最 后 一 页 则 显示 ” 


3) 完成 后 在 每 个 套用 “显示 区 域 ” 的 “服务 器 行为 ”的 部 分 会 出 现 “ 如 果 符 合 此 条 
件 则 显示 …” 的 提示 文字 ， 如 图 3-49 所 示 。 
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phpweb - C 













































记录 集 (Rsdb) 
显示 总 记录 数 Rsdb) 
显示 起 始 记录 编号 Rsd) 

显示 结束 记录 编号 (Rsdb) 

重复 区 域 (Rsdb) 

动态 文本 (Rsdb. ID) 

动态 文本 (Rsdb. name) 

动态 文本 (Rsdb.age) 

动态 文本 (Rsdb. Result) 

如 果 不 是 第 一 页 则 显示 (Rsdb) 
移 至 第 一 页 (Rsdb) 

如 果 不 是 第 一 页 则 显示 (Rsdb) 
移 至 前 一 页 (Rsdb) 

如 果 不 是 最 后 一 页 则 显示 (sdb) 
移 至 下 一 页 (Rsdb) 

如 果 不 是 最 后 一 页 则 显示 (sdb) 
移 至 最 后 一 页 (Rid) 





HA {Rsdb.TotalRecords} 笔记 录 ， 目 前 查看 第 {Rsdb.FirstRecord} 笔 至 第 {RsdbLastRecord} 笔 
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图 3-49 JH “ERKI” AU 


4) 最 后 按 (F12) f, fewer RAR, WE 3-50 所 示 。 
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PHP*-MySQL-4* Dreamweaver 动态 网 站 开发 从 入 门 到 精通 
























































































































































elak) 
S J| & http//127.0.0.1/phpweb/index.php?pageNum Rsdbz-1&totalRows Rsdb-: O ~ BO X| N vy i93 
您 pHp 动 坊 系统 x luu 
PHP 动 态 系统 T 
共有 11 笔记 录 ， 目 前 查看 第 6 笔 至 第 10 笔 
| 序号 姓名 年 龄 成 绩 
| 6 testó 21 66 
| 1 test7 22 95 | 
8 test8 23 87 [ 
9 testo 24 69 
10 test10 23 68 
En | u-u I A | REN | 














K 3-50 设置 “显示 区 域 ” 后 的 效果 





也 可 以 在 Dreamweaver 菜单 中 选择 “插入 ”一 “数据 对 象 ” 一 “记录 和 集 (Recordset) 
分 页 ”一 “记录 和 集 导 航 条 ”命令 ， 来 快速 地 插入 一 个 分 页 区 域 。 





JL 显示 详细 信息 


很 多 时 候 ， 并 不 会 开始 就 将 数据 库 所 有 字段 、 记 录 都 显示 出 来 。 例 如 ， 一 个 新 闻 系 统 ， 
在 首页 只 会 显示 新 闻 的 日 期 与 标题 ， 更 详细 的 新 闻 内 容 需要 选择 标题 进入 到 另 一 个 页 面 才 能 
显示 。 假 设 显示 新 闻 标 题 的 页 面 是 index. php， 而 显示 详细 新 闻 内 容 的 网 页 名 称 为 
detail. php。 当 在 index. php 中 点 击 标题 的 链接 后 ， 此 时 该 超级 链接 会 带 着 一 个 参数 到 
detail. php， 网 址 类 似 于 detail. php? ID =1。 多 出 的 ID =1 是 一 个 变量 名 为 ID ， 值 为 1 的 
URL 参数 。 当 detail. php 收 到 ID 21 的 URL 参数 后 ， 便 利用 这 个 URL 参数 在 建立 记录 集 时 











筛选 所 指定 的 新 闻 记录 ， 并 将 记录 详细 信息 显示 在 网 页 上 。 这 样 就 构成 了 一 个 简单 的 新 闻 系 
统 架 构 。 要 筛选 指定 的 记录 可 以 在 SQL 中 使 用 WHERE FAJ, Æ Dreamweaver 中 有 相应 的 图 
形 界 面 可 以 方便 使 用 。 下 面 ， 看 看 Dreamweaver 是 如 何 运用 传送 与 接收 URL 参数 来 筛选 出 指 
定 的 记录 。 

1) 使 用 Dreamweaver 创建 一 个 空白 的 detail. php 页 面 并 保存 。 在 index. php 中 选择 要 用 
来 连接 到 详细 信息 页 面 的 部 分 〈 其 实 就 是 选择 要 在 哪里 建立 超级 链接 ) ， 在 本 例 中 选择 序 
号 ， 即 选择 | Rsdb. ID} 动态 文字 ， 如 图 3-51 所 示 。 

PHP 动 态 系统 











姓名 年 龄 成 绩 
(Rsdb.name) (Rsdb.age) (Rsdb Result) 
| E DRESEERETUESEDUTS DENN 各 果 符 合 此 条 件 由 | 旦 示 ， 


Hm en 


图 3-51 选中 动态 文字 |Rsdb. ID} 
2) 在 下 面 的 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 “浏览 文件 ”图 标 辑 ， 如 

































如 果 符 合 此 条 件 由 显示 




















图 3-52 所 示 。 
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属性 

ERP | 无 类 v BJ tizizfts?5 (MEC) 

Bn css ma) X w| ERL) [LN N 目标 (6) 

a9 单元 格 KFORU v| Xo TATOO *REeGJ| ps L mmm. 
— ns Bo v 高 中 ramo 




















图 3-52 ”建立 链接 设置 
3) 在 弹出 的 对 话 框 中 选择 用 来 显示 详细 记录 信息 













的 页 面 detail. php， 如 图 3-53 所 示 。 



































| por 计算 机 ， Acer (C) » xampp » htdocs ^» phpweb » 
P - 
| 组织 ”新建 文件 夫 = m e 
| A 最 乒 访 问 的 位 置 ^ 名称 修改 日 期 zm 大 小 
|; .mmServerScripts 2014/12/7 16:20 xd 
lad 具 .notes 2014/12/7 18:41 X 
Bus |; Connections 2014/12/7 16:00 ”文件 夫 
| liz] 图 片 | date 2014/12/7 16:00 文件 去 
国 xc =| [Ljdetailphp 2014/12/7 18:04 — PHP 文件 OKB| 
E) RETE Li index.php 2011/7/30 10:26 PHP 文件 5 KB 
"ES 
m 计算 机 
ü& Acer (C:) 
ca 本 地 磁盘 (D:) 
c DRR E T 
=z 
ZIZIN): detail.php - [Fee -| 
站 点 根 目录 确定 “| Bü 














图 3-53 设置 链接 的 文件 








4) 如 果 仅 仅 是 这 样 ， 那 只 会 是 单纯 的 超级 链接 ， 并 没有 附带 URL 参数 。 因 此 ， 要 设置 超 
级 链接 要 附带 的 URL 参数 的 名 称 与 值 。 本 例 将 参数 名 称 命名 为 ID ， 接 收 上 一 页 传递 过 来 的 
ID 值 。 

5) 地 址 变 成 detail php? ID = <? php echo $row, rsdb[ ID ]; ? > ， 如 图 3-54 所 示 。 













































































尾 性 

dex) | 无 ~ 类 z ss ors GERD 

B css ID X ~| ERO DETCESUETUGSOBNE v (o0) BRO ~ 

er] 单元 格 KFORU v| EW 7O00 *RE&G 厂 -| (CREER... - 
— nk aou v 高 四 标题 到 ) 口 ] 























图 3-54 选择 ID 字段 


6) 设置 完成 后 ， 可 以 在 浏览 器 打开 index 页 面 。 可 以 看 到 ， 每 一 条 记录 的 链接 都 带 着 
URL 参数 中， 其 值 是 每 条 记录 的 ID ， 如 图 3-55 所 示 。 

前 面 已 经 完成 了 index. php 中 应 该 完成 的 部 分 ， 下 面 来 看 看 接收 URL 参数 的 detail. php 
如 何 用 收 到 的 参数 来 筛选 指定 的 记录 。 

1) 打开 detail. php 页 面 后 选择 “ 绑 定 ”面板 ， 单 击 “ 
选择 “记录 集 (查询 ) Mme, WK 3-56 所 示 。 


+” 按 钮 ， 从 弹出 的 下 拉 菜 单 中 




















了 PHP 动态 系统 























共有 11 笔记 录 ， 目 前 查看 第 1 笔 至 第 5 笔 
姓名 





















































| 序号 年 龄 成 绩 
| 1 test] 21 100 
| 2 test? 22 98 | 
3 test3 22 86 f 
4 test4 21 89 | 
test5 23 74 
[下 一 页 ] [最 后 一 页 ] 









































http://127.0.0.1/phpweb/detail.php?ID=5 




















图 3-55 单 击 链接 的 属性 显示 


2) 打开 “记录 集 ” 对 话 框 ， 在 该 对 话 框 中 进行 如 下 设置 。 

o 在 “名 称 ” 文 本 框 中 输入 rsdetail 作为 该 “记录 和 集 ”的 名 称 。 

e 从 “连接 ”下 拉 列 表 框 中 选择 “webconn” 连接 对 象 。 

。 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 websql。 

e 在 “ 列 ” 单 选 按钮 组 中 选择 “全 部 ” 单 选 按钮 。 

e 在 “筛选 ” 栏 中 设置 记录 集 过 滤 的 条 件 为 ID = URL 参数 / ID。 

完成 后 的 设置 如 图 3-57 所 示 。 

3) 如 果 想 知道 SQL 语句 ， 可 以 单 击 “高 级 ”按钮 。 在 “高 级 ”界面 测试 SQL 语句 ， 
如 图 3-58 所 示 。 在 SQL 语句 中 的 colname 是 一 个 变量 ， 若 筛选 的 时 候 有 用 到 变量 ，Dream- 
weaver 就 会 用 这 个 变量 名 称 放 在 SQL 语句 里 。 而 这 个 变量 的 值 会 是 什么 呢 ? 就 是 下 面 “ 变 
量 ” 区 域 中 colname 的 运行 值 的 定义 。 当 网 页 运作 时 ，colname 将 等 于 URL 变量 ID 的 值 ($ 
_GET [ ID ])， 所 以 当 URL 变量 ID 值 不 同 ， 筛 选 出 的 结果 也 不 同 。 























































































































Fm =S) 
2: | Low 
连接 : |webeonn -EX B 
表格 : |websal -| -= 
»KO em O 选 定 的 —— 
ID E] 
Result 
jos: [10 z=] x 
WL 参数 x| ID 
排序 : 无 了 [升序 
3-56 选择 “记录 集 (查询 )” 图 3-57 设置 “记录 集 ” 对 话 框 








4) 然后 单 击 “确定 ”按钮 ， 完 成 记录 集 建立 。 记 录 集 建立 完毕 后 ， 可 以 把 各 个 字段 拖 
动 到 页 面 上 相应 的 单元 格 中 ， 如 图 3-59 所 示 。 以 上 详细 页 面 的 制作 就 算 大 功 告 成 了 。 
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名 称 : [mr m 
取消 
连接 : | webeonn »] E 
€ ; 测试 
: t ^ r 
er FROM websql FT 
WHERE ID = colname 
| 帮助 
变量 : = 
| | 名 种 : colname 
类 型 Integer 
默认 值 : -1 
运行 值 : $_GETTID1] 
数据 库 项 : 表格 添加 到 SAL: 
mg 视图 
d. 预存 过 程 SELECT 
WHERE 
| ORDER BY 
| 
U cd J 

















图 3-58 ”高 级 “记录 集 ” 对 话 框 

















Dw 2AP S86 ZEV) 插入 修改 (M) 格式 (0) SO HAS SOW WH | Hm. © 一 
Si xi \htdocs\phpweb n 
webconn. php 




















E fis RC SEE] 
了 PHP 动态 系统 SQ 记录 集 (sdetail) 
es ] : 7 ID 
z3 " z - - f nane 
号 姓名 年 龄 成 绩 编辑 C4 age 
(rsdetalID) |{rsdetainame} —— |(rsdetalage] ^ |(rsdetalResu)| — [EX / MA bs 
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er 单元 格 。 水 平 C) | 默认 MEO TOL] 背 景 颜色 ON THEE... ) 
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图 3-59 制作 的 详细 页 面 


3) 完成 后 直接 按 (F12〉 键 在 浏览 器 中 打开 detail. php， 发 现 内 容 是 空白 的 ， 如 图 3-60 所 
示 。 这 是 怎么 回 事 呢 ? 因为 在 网 址 后 面 没 有 带 着 URL 人 参数， 当然 记录 集 里 就 不 会 有 任何 东西 。 
mA 


Oe http://127.0.0.1/phpweb/detail.php p-Box| DÈ 
E ramm x 


了 PHP 动态 系统 















































s E FA D JER 












































| 更 新 / 删除 


























图 3-60 显示 为 空白 
6) 直接 在 网 址 后 加 上 URL 变量 ID ， 其 值 可 以 选 1 ~ 10 的 任何 一 个 值 ， 然 后 按 《Enter》 
键 ， 网 页 显示 的 结果 如 图 3-61 所 示 。 
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E 
(B http;//127.0.0.1/phpweb/detail.php?1D-6 P- BOX| D v 9 
了 PHP 动态 系统 
序号 姓名 年 龄 成 绩 编辑 
6 [testé 21 66 更 新 /删除 
图 3-61 URL 参数 ID =6 时 的 详细 页 面 


7) 在 index. php 中 ， 每 一 笔记 录 的 网 址 都 带 有 特定 的 参数 链接 到 detail. php， 如 图 3-62 
































































































































所 示 。 
| [eI 
a: S @ http://127.0.0.1/phpweb/index.php?pageNum Rsdb-1&totalRows Rsdb-: O ~ BO X| (5 vy i9? 
d 
PHP 动 态 系统 T 
共有 11 笔记 录 ， 目 前 查看 第 6 笔 至 第 10 笔 
[ F Ez mE |] 
| 6 testó 21 66 | 
[ F test7 22 95 | d 
8 test8 23 87 
9 test9 24 
[一 二 一 一 党 一 一 上 一生 一 
n | a I] r-m I] E£-m 
| http://127.0.0.1/phpweb/detail.php?ID=10 | [ER 
` A 








图 3-62 单 击 首页 上 的 链接 
8) 单 击 第 10 个 链接 后 ， 打 开 指 定 记 录 的 详细 页 面 ， 如 图 3-63 所 示 。 
| 


- 
Æ http//127.0.0.1/phpweb/detail.php?ID- 10 P- Box re 
Q vemm x B ~ - E 




















































































































| PHP 动 态 系统 
序号 名 & 成 绩 编辑 
[10 st10 23 68 | 更新/ RP | 
— —— 一 y 





图 3-63 打开 指定 记录 的 详细 页 面 
| Section. 
ETE 编辑 记录 功能 


前 面 介绍 了 如 何 将 位 于 数据 库 中 的 记录 拖 到 网 页 上 显示 。 本 节 将 介绍 新 增 、 更 新 以 及 删 


UP 新 增 记录 功能 


在 数据 表 websql 中 有 4 个 字段 ， 其 中 ID 字段 为 主键 上 且 附 加 了 auto. increment 属性 ， 








Dreamweaver+PHP 开 发 基础 





此 在 新 增 记 录 时 不 必 考 虑 ID 字段 ， 只 需 增 加 3 个 字段 即 可 。 





实现 的 步骤 如 下 。 
1) 创建 一 个 空白 的 php 网 页 ， 并 命名 为 add. php， 先 添加 一 个 表单 ， 再 插入 一 个 4 x2 
表格 ， 键 入 相关 提示 后 依 序 放 上 3 个 文本 字段 、 两 个 按钮 ， 完 成 后 如 图 3-64 所 示 。 C» 
= 














DW E $86  ESB(V) EAM 修改 (M) 格式 (0) 命令 (Q HAS) ”窗口 (W) 帮助 (H) Hm. © 
add.php* x hpweb\add.php 
(ORB Ln | 









iue iem "E m 








设计 | 实时 视图 | 








* 一 ”文档 类 到 : ne 







































































LH 
PHP 动 态 系统 着 要 在 该 页 面 上 使 用 动态 数据 : 
w> Y 1 请 为 该 文件 创建 一 个 站 点 。 
——— NS Le aM T M] Y 民选 泽 一 种 文档 类 型 
姓名 ， LEES 
年 龄 : 4. 按 加 号 CO 按钮 并 选择 记录 集 。 
成 绩 ， 
提交 
» Body form #torml tee tr td E E exce 












ura mupo[z 0 v) LI 
css | ID(I) Result ~ RO 


ep ses rroga JAW) mÁGSOO! WEBeOL] —— ZG... 
一 3p moga -Jaw ior 
















































































图 3-64 ”建立 表单 并 设计 网 页 


当 需 要 新 增 、 更 新 记录 时 ， 网 页 中 需要 有 一 个 表单 且 表 单元 素 必须 置 于 表单 内 ， 在 单 击 
按钮 后 ， 只 有 在 表单 内 的 元 素 会 被 以 POST 或 GET 的 方式 传递 。Dreamweaver 中 的 新 增 、 更 
新 记录 都 是 将 表单 元 素 的 值 以 POST 的 方式 传递 给 页 面 ， 当 程序 判断 到 指定 字段 (新 增 记录 
时 ， 字 段 名 为 MM_insert， 当 使 用 了 “插入 记录 ”服务 器 行为 时 该 字段 将 被 自动 添加 ) 送出 
了 POST 信息 〈 值 为 窗 体 名 称 ) ， 便 执行 新 增 、 更 新 记录 等 部 分 的 程序 。 

2) 插入 3 个 文本 字段 ， 并 分 别 选择 各 个 文本 字段 ， 并 在 “属性 ”面板 上 为 其 命名 ， 分 别 是 
姓名 Name、 年 龄 Age 、 成 绩 Result， 注 意 在 设计 时 要 与 记录 集 字 段 名 称 一 一 对 应 ， 如 图 3-65 



























































所 示 。 
Dw 2HP $86 SEV 插入 (1 修改 (M) ”格式 (D) SNO HASO SOW WRH) Ba e. (Oj 
| msg [X] mimm Q. 标题 添加 记录 js | 
addphp x m 本 地 视图 z) 
GRE webconn. php 


[e]o|*t: t e|m 





了 PHP 动态 系统 
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3-65 命名 文本 域 









QL*Dreamweaver 动态 网 站 开发 从 入 门 到 精通 





说 阴 : 

当 表 单元 素 的 命名 与 记录 集 字段 相符 合 时 ， 在 做 “新 增 记录 ”“ 更 新 记录 ”时 ，Dream- 
weaver 会 自动 将 表单 元 素 与 记录 集 字段 相 匹配 。 

3) 选择 “服务 器 行为 ”面板 ， 单 击 “+ ”按钮 ， 从 弹出 的 下 拉 菜 单 中 选择 “插入 记 
录 ” 命 令 ， 如 图 3-66 所 示 。 























Dw 文件 869 SEV 插入 (1 修改 (M) 格式 (0) 命令 (C) ”站 点 (S$) SOW WMH) HB. zB 
addphp* x phpweb - CAXAM docsiphpwebadd.php 
”代码 | 拆 分 












标题 添加 记录 
PHP 动 态 系统 





设计 | 实时 视图 | Q. 
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图 3-66 执行 “插入 记录 ”命令 


4) 打开 “插入 记录 ”对 话 杠 ,设置 插入 记录 属性 ， 选 择 连 接 为 webconn, WARE 
websql， 这 是 设置 要 将 记录 添加 到 哪 一 个 数据 表 中 。 在 选择 完 数据 表 后 ,，“ 列 ”区 域 中 便 会 
出 现 该 数据 表 内 的 所 有 字段 ， 可 以 在 这 里 设置 哪个 数据 表 字 段 要 从 表单 中 的 哪个 元 素 获取 
值 ， 具 体 的 设置 如 图 3-67 所 示 。 
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插入 后 ， 转 到 : index. php NEN 
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图 3-67 设置 “插入 记录 ”对 话 框 


Hi 





说 明 : 

之 前 将 表单 元 素 的 命名 与 数据 库 字段 名 称 相同 ， 所 以 在 建立 “插入 记录 ”时 Dream- 
weaver 便 会 自动 将 它们 配对 。 也 可 以 先 选择 欲 设置 的 字段 ， 由 “ 值 ” 右 方 的 下 拉 式 菜单 中 
选择 从 哪个 表单 元 素 取得 值 。 然 后 在 “插入 后 ， 转 到 ”的 文本 字段 框 填 上 index. php。 将 表 
单元 素 的 名 称 与 数据 库 内 的 字段 名 称 命名 为 相同 ,除了 “插入 记录 ”以 外 ,“ 更 新 记录 ” 服 











Dreamweaver+PHP 开 发 基础 





务 器 行为 也 会 将 相同 名 称 的 数据 列 与 表单 元 素 自 动 配对 在 一 起 。 

5) 设置 完成 后 ， 在 “服务 器 行为 ”面板 的 列表 中 就 会 多 出 一 项 插入 记录 如 图 3-68 所 
示 ， 可 以 双击 该 项 重新 进行 “搬入 记录 ”的 设置 。 完 成 后 网 页 上 的 表格 会 变 成 浅 绿色 的 底 ， 
当然 这 并 不 是 表示 有 错误 ， 而 是 表明 该 表单 使 用 了 “服务 器 行为 "。 同 时 ， 在 表单 内 也 自动 G) 
加 上 了 名 称 为 MM_insert 的 隐藏 字段 ， 用 来 判断 用 户 是 否 单 击 “ 提 交 ” 按 钮 送出 信息 ， 并 是 
否 执行 “插入 记录 ”部 分 的 程序 代码 。 
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cs\phpweb\add php 











addphp x 
webconn. php 





* - 文档 类 型 : nm 
插入 记录 (forml, webconn, websql) 
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图 3-68 插入 记录 后 的 页 面 效果 


6) 直接 按 (FI12〉 键 在 浏览 器 中 打开 网 页 ， 输入 值 如 图 3-69 所 示 ， 并 单 击 “ 提 交 ?” 
按钮 尝试 新 增 一 笔记 录 。 







































































LE ÈS 
oe http://127.0.0.1/phpweb/add.php p-Boxl QÈ 
合 添 加 记录 x 
PHP 动 态 系统 
姓名 ， test11 
年 龄 : 10 
成 绩 ， 58| 















































3-69 输入 记录 数据 


7) 单 击 “ 提 交 ” 按 钮 后 ， 网 址 将 从 add. php 转 至 index. php。 点 击 网 页 下 方 的 分 页 导航 
条 的 [最 后 一 页 ] 链 接 ， 便 可 以 看 到 刚才 新 增 的 记录 ， 如 图 3-70 所 示 。 

程序 说 明 : 

简单 地 来 看 看 这 部 分 的 程序 代码 是 怎样 的 。 表 单 的 “动作 ”为 <? php echo $editForm 
Action; ? > (如 图 3-71 所 示 ) ， 在 单 击 按钮 后 网 页 是 将 信息 以 POST 的 方式 送 给 自己 ， 所 
以 先 记 住 这 个 变量 后 切换 至 “代码 ”视图 。 在 “代码 ”视图 中 可 以 看 到 $editFormAction X 












量 的 值 如 图 3-71 Hr, $ SERVER 是 预定 义 变 量 的 一 种 ， 用 以 提供 服务 器 的 相关 信息 ; 而 
$ SERVER[ PHP SELF ] 便 是 返回 该 网 页 的 文件 名 称 。 所 以 表单 的 " 动作 " 为 <? php 































































































| PHP 动 态 系统 
| 
共有 11 笔记 录 ， 目 前 查看 第 11 笔 至 第 11 笔 I 
序号 姓名 | 年 龄 | 成 绩 | 
12 test11 10 58 | 
EA MA 











图 3-70 增加 记录 后 的 效果 


echo $editFormAction; ? > 就 意味 着 ， 将 表单 数据 以 POST 方式 传递 给 自身 。 


接着 看 到 被 自动 添加 的 隐藏 字段 MM_insert， 其 值 是 forml ， 与 所 在 位 置 的 表单 名 称 一 





动作 <?php echo $editFormAction: ?> DO Bm ` 
方法 POST ~ 编码 类 型 ` 
























































3-71 表单 动作 参数 


致 。 代 码 的 窗口 如 图 3-72 所 示 。 
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index.php x 
webconn. php T 
代码 | demo bit +, 
n 30 return $theValue; ^ 
Bs } 
3€ 32 1 
s| 33 
al 34  $currentPage - $ SERVER["PHP SELF"]; 
« 35 2 
36 $maxRows_Rsdb = 5; 
8B 37 $pageNum_Rsdb = 0; 
|38 if (isset($_GET['pageNum_Rsdb'])) { 
fi] 39 $pageNum Rsdb = $ GET['pageNum Rsdb']; 
PS 40 
41  $startRow Rsdb = $pageNum Rsdb * $maxRows Rsdb; 
cz 42 
加 3 mysql select db($database webconn, $webconn); 
44  $query Rsdb = "SELECT * FROM websql"; 
Q 45  $query limit Rsdb = sprintf("%s LIMIT %d, %d", $query_Rsdb, $startRow_Rsdb, $maxRows Rsdb); 
*| 46  $Rsdb = mysql query($query limit Rsdb, $webconn) or die(mysql error()); 
47  $row Rsdb = mysql fetch assoc($Rsdb); 
48 -T 
LI 


<? MSEE 








if (!function_exists ("GetSQLValueString")) { 
function GetSüLValueString(f$theValue, $theType, $theDefinedYValue = "", $theNotDefinedValue = "") 





if (PHP VERSION < 6) { 


$theValue = get magic quotes gpc() ? stripslashes($theValue) : $theValue; 


图 3-72 ”代码 窗口 





入 门 到 精通 








核心 的 代码 说 明 如 下 : 



































if ( (isset( $. POST[ " MM. insert" ]) ) && ($_POST["MM_insert"] = = "forml")) | 
// 判 断 表 单 变量 $ POST[ MM. insert. ] 是 否 被 设置 , 且 值 是 否 等 于 forml。 如 果 是 , 则 执行 下 面 的 
插入 记录 动作 。 > 








$insertSQL = sprintf(" INSERT INTO websql ( Name, Age, Result) VALUES (%s, %s, %s)", 
// 定 义 了 SQL 语句 。 
GetSQLValueString( $_POST] Name ], "text" ) ， 
GetSQLValueString( $_POST] Age ], "int"), 
GetSQLValueString( $_POST] Result ], "text" )) ; 
// 取 值 表单 的 变量 。 
mysql. select. db( $database webconn, $webconn); 
$Resultl = mysql query( $insertSQL, $webconn) or die( mysql error( ) ) ; 
/连接 数据 库 执行 SQL 语句 。 
$insertCoTo = "index. php" ; 
// 设 置 了 在 "插入 记录 "后 要 跳 转 的 文件 index. php , 它 被 存储 在 变量 $insertGoTo。 


D EJU RIRE 


更 新 记录 功能 是 指 将 数据 库 中 的 旧 数 据 根据 需要 进行 更 新 的 操作 。 这 里 会 用 前 面 已 经 使 
用 到 的 detail. php 文件 。 

更 新 记录 功能 的 操作 步骤 如 下 。 

1) 打开 detail. php 网 页 后 ， 选 中 “更 新 ”， 如 图 3-73 所 示 。 
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* - 文档 类 型 : PIP 






































í 设计 ] mim um PANE | 4t 
| 代码 | 拆 分 [ 设计 ] 实时 视图  Q. nm usum | 4t CER CoD 
E 动态 文本 (rsdetail ID) 
PHP 动 态 系统 动态 文本 (rsdetail.name) 
—Ó 6007 ES 动态 文本 (rsdetail.name) 
X = ~ z z - 动态 文本 (rsdetail Result) 
序号 姓名 年 龄 成 绩 编辑 
{rsdetal ID} |{rsdetailname} ^ |(rsdetalname) “ (rsdetaiResuk) E2 / HIER 


























K body w tr td [- B E EH 72 x 33v 










































Et 

[Come] RED [无 m X 无 = = 
bcs WW) 无 ~ BHEO Og BRO - 
国 单元 格 KPO ë Aw) TATOO SERAESBODI ^| 页 面 属性 
— cap sBo(NA aw HAD 





























3-73 ”选择 链接 文字 


2) 在 “属性 ”面板 中 ， 单 击 如 图 3-74 所 示 的 “浏览 文件 ”图 标 ， 为 其 建立 附带 URL 
参数 的 超级 链接 。 











属性 
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Bs css ma) X v) EEL) EAEN 目标 (6) 
a 单元 格 KFORU v| EW 不 换行 »[] anec Dkr] 

— cp o BO v 高 om ramo 




















[3-74 单 击 “浏览 文件 ”图 标 


3) 输入 用 来 更 新 记录 使 用 的 update. php 页 面 ， 接 着 单 击 “ 浏 览 文件 ”按钮 功 ， 为 其 
建立 名 称 为 ID ， 值 是 rsdetail 记录 集 ID 字段 值 的 URL 参数 


4) 完成 后 的 链接 地 址 : update. php? ID = <? php echo $row_rsdetail[ ID ]; ? >// 传 
3$ ID 到 update. php 页 面 ， 如 图 3-75 所 示 。 

































































属性 

Tex 0) 无 v 类 无 v BZ Z 55 t 2s Aa) | 
Es css ma) X v| BHEL) (update. php?ID=<?php echo $rov v | Gy C) 目标 (6) [| 
国 单元 格 KFORU vian TÉ OD) ameo N] 

— oj o £BORU ~| 高 中 ramo 








3-75 传递 ID Æ update. php 


5) 创建 update. php 文件 。 开 始 的 操作 与 之 前 在 制作 记录 详情 页 面 detail. 时 相同 
都 是 利用 接收 到 的 URL 参数 筛选 指定 记录 。 在 “服务 器 行为 ”面板 中 , Wah "€ PEU, 
从 弹出 的 下 拉 菜 单 中 选择 “记录 集 (查询 ) ”命令 ， 如 图 3-76 所 示 。 
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图 3-76 选择 “记录 集 (查询 )” 


6) 打开 “记录 集 ” 对 话 框 ， 在 该 对 话 框 中 进行 如 下 设置 。 
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e 在 “名 称 ”文本 框 中 输入 rsupdate FH (ess =) 
该 “记录 集 ” 的 名 称 。 mmm | Ca 
。 从 “连接 ”下 拉 列 表 框 中 选择 “web- || 57 mam = 二 一 | 一 
conn" 连接 对 象 。 | CR 
。 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 hgg 
数据 库 表 对 象 为 websql。 

。 在 “ 列 ” 单 选 按 钮 组 中 选择 “全 部 ” s 

单 选 按钮 。 




















e 在 “筛选 ” 栏 中 设置 记录 集 过 滤 的 条 件 
为 ID =URL 参数 / ID。 
完成 后 的 设置 如 图 3-77 所 示 。 
7) 将 页 面 中 应 该 有 的 表单 、 文 本 字段 、 
按钮 设置 完成 ， 在 “ 绑 定 ”面板 中 将 记录 集 内 的 字段 拖 动 至 页 面 上 各 对 应 的 文本 字段 中 ， 
如 图 3-78 所 示 。 
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3-77 设置 “记录 集 ” 对 话 框 
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webconn. php T 
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8 camcn: | + 一 文档 类 型 : PHP 
H 设计 | 实时 视图 ， mE. 更 新 页 | 
LA lio [设计 | sums Q. 标题: EHE S | 性 记录 集 (rsupdate) 
HA 动态 文本 域 GD) 
PHP 动态 系统 动态 文本 域 Game) 
SEE 600~ LIII 动态 文本 域 (age) 
DES z - - : - | HEXER Result) 
序号 姓名 年 龄 成 绩 
{rsupdate.ID} | —— | [rsupdate.name]| 位 supdate age} | {rsupdate. Resul] 
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li css | IDC) Result [ | 
sF) 单元 格 KEDRA £|]AEo | | TATOO RABON | 页 面 属性 ... 
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图 3-78 JPET 


8) 由 于 ID 是 主键 ， 不 能 随便 变更 主键 的 值 ， 因 此 选择 ID 部 分 的 文本 字段 ， 单 击 选 择 
文本 字段 ， 如 图 3-79 Bros s 

9) 在 “属性 ”面板 中 ， 选 中 “Read Only (只 读 )” 复 选 框 ， 如 图 3-80 所 示 。 通 过 这 
样 的 设置 ， 这 个 字段 便 不 能 被 用 户 修改 。 

10) 然后 再 单 击 “ 服 务 器 行为 ”面板 中 单 击 “+ ”按钮 ， 从 弹出 的 下 拉 菜 单 中 选择 
“更 新 记录 ”命令 ， 如 图 3-81 所 示 。 

11) 打开 “更 新 记录 ”对 话 框 ， 设 置 更 新 记录 的 参数 。 选 择 “连接 ”webconmn 后 ， 
个 表单 元 素 与 字段 都 会 自动 匹配 好 ， 只 需 在 “在 更 新 后 ， 转 到 ”输入 框 填 上 index php, Al 
图 3-82 所 示 。 
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| 600 
序号 姓名 年 龄 成 绩 
[lrsupdate. ID] N [ {rsupdate. name] | frsupdate. agel | [ {rsupdate. Resul| 
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form form] table tr Xd» [input» *ID 
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图 3-79 设置 “编辑 标签 ” 
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updatephp* Xx 
webconn. php 
| 代码 | 拆 分 [设计 | 实时 视图 | Qo pa Eyam | 4t. 
PHP 动 态 系统 

600~ 
REESE J z : i s — z NUI 

序号 姓名 年 龄 成 绩 

| {rsupdate. nane}| | [rsupdate.age] | {rsupdate. Resul 

IP m 
[Xf5. body form #fornl table tr td B E EH 6x25. 










































































HB ^ 
mE 
TAI Name ID Class X - Size 16 Value <?php echo $ro| 47 Title 
Maxlengh | | Place Holder 
"Disabled ^ | ]Requred | |Auto Complete | Form ~ | Pattern. TabIndex | | List 
'jAutoFocus [4|Read Only 
图 3-80 设置 为 “只 读 ”属性 
Dw 文件 (RP S5 SSV) EAD 修改 M) RO) | Ee -| EE olal x 









































Class 无 Size 16 Value <?php echo $ro|47 Tite | 

Max Length Place Holder | 

T] Auto Complete | Form ~ | Pattern Tab Index | 
图 3-81 执行 “更 新 记录 ”命令 
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提交 值 ， 自 : [form 确定 Jj 
连接 : [webeonn =) 取消 
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z: ERES Rir Ai 





Tu. nra x 





























IE 
提交 为 : | 整数 | 六 主键 
在 更 新 后 ， 转 到 : index. php 0 GR 























图 3-82 设置 “更 新 记录 ”参数 


12) 单 击 “ 确 定 ” 按 钮 ， 完 成 后 页 面 的 表格 同样 会 被 套 上 浅 绿色 的 底 ， 而 表单 中 也 会 
多 出 一 个 隐藏 字段 ， 名 称 为 MM_update， 值 与 表单 名 相同 ， 如 图 3-83 所 示 。 
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PHP 动 态 系统 动态 文本 域 (D) 
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: 序号 姓名 年 龄 成 绩 动态 文本 域 Result) 
; | {rsupdate. ID] Írsupdate. name} [rsupdate. age} Írsupdate. Resul 
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图 3-83 ”完成 的 页 面 效果 


13) 最 后 在 浏览 器 中 打开 index. php， 选 择 最 后 一 笔记 录 到 详情 页 面 detail. php， 然 后 在 
详情 页 面 选择 “更 新 ”链接 ， 如 图 3-84 所 示 。 

14) 在 update. php 中 可 以 修改 姓名 、 年 龄 与 成 绩 的 字段 值 ， 而 ID 文本 字段 是 不 能 被 修 
改 的 。 更 改 完成 后 ， 单 击 “ 更 新 ”按钮 ， 如 图 3-85 所 示 。 

返回 到 index. php ， 检 查 该 笔记 录 是 否 被 正确 更 新 ， 如 图 3-86 所 示 。 

这 部 分 的 程序 代码 与 插入 记录 基本 相同 ， 差 别 只 在 于 隐藏 字段 的 名 称 不 同 ， 使 用 的 是 
UPDATE 语句 。 
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图 3-84 单 击 “ 更 新 ”链接 
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ERU] x luni 
PHP 动 态 系统 
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3-85 ”修改 数据 
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图 3-86 完成 更 新 的 功能 页 面 


sponso 删除 记录 功能 


删除 记录 功能 是 指 将 数据 从 数据 库 中 删除 ， 使 用 “服务 器 行为 ”中 的 “删除 记录 ” 命 
令 即 可 以 实现 。 
具体 的 实现 步骤 如 下 。 








1) 使 用 超级 链接 带 着 URL 参数 转 到 删除 页 面 del. php。 首 先 在 detail. php 中 选中 “ 删 


除 ”"， 在 “属性 ”面板 中 建立 链接 ， 如 图 3-87 Bram. 
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图 3-87 设置 “删除 ”链接 




















2) 因为 删除 记录 还 是 依据 主键 的 ID 字段 ， 故 选择 删除 记录 所 用 文件 del. php， 并 附带 


URL 参数 ， 其 名 称 为 ID， 值 为 rsdetail 记录 集 的 ID 字段 值 ， 如 图 3-88 所 示 。 
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代码 ? <?php echo $row rsdetaill'']; ?> 
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动态 属性 (a href, $row rsdetaill' ID ]) 
动态 属性 (a href, $row rsdetaill'ID']) 










































[3-88 设置 传递 的 参数 属性 


3) 单 击 “ 确 定 ” 按 钮 ,这样 就 完成 了 detail. php 的 修改 工作 ， 接 下 来 开始 修改 
del. php。 创 建 del. php 文件 ， 在 “ 绑 定 ”面板 中 单 击 “+ ”按钮 ， 从 弹出 的 下 拉 荣 单 中 选 


择 “ 记 录 集 (查询 ) ”命令 ， 如 图 3-89 所 示 。 












e 























Dw  xéP #89 SEV) EAM 修改 (M) 格式 (0) 命令 (C) ”站 点 (S$) SOW SH) Hm. OE X 









| 9. mu Meam | 村 








pn 姓名 F RA 






























































B D EH 631 x 343v 


























[3-89 选择 “记录 集 (查询 ) ”命令 


4) 打开 “记录 集 ” 对 话 框 ， 在 该 对 话 框 中 进行 如 下 设置 。 

o 在 “名 称 ” 文 本 框 中 输入 rsdel 作为 该 “记录 集 ” 的 名 称 。 

e 从 “连接 ”下 拉 列 表 框 中 选择 webconn 连接 对 象 。 

。 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 websql。 
e 在 “ 列 ” 单 选 按钮 组 中 选择 “全 部 ” 单 选 按钮 。 

e 在 “筛选 ” 栏 中 设置 记录 集 过 滤 的 条 件 为 ID = URL 参数 / ID。 
完成 后 的 设置 如 图 3-90 所 示 。 
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图 3-90 设置 “记录 集 ” 对 话 杠 





5) 将 各 个 记录 集 字 段 拖 动 到 页 面 中 所 对 应 的 文本 框 后 ， 将 “删除 ”按钮 命名 为 Del, 
接着 在 “服务 器 行为 ”面板 中 单 击 “+ ”按钮 ， 从 弹出 的 下 拉 菜单 中 选择 “删除 记录 ” 命 
令 ， 如 图 3-91 所 示 。 

6) 在 弹出 的 “删除 记录 ”对 话 框 中 ， 进 行 如 图 3-92 所 示 的 设置 。 

“主键 列 ” 与 “主键 值 ” 所 设置 的 是 删除 记录 的 依据 ， 这 里 的 依据 是 指 在 DELETE- 
FORM 数据 表 WHERE 条 件 里 的 条 件 ， 假设 条 件 是 WHERE ID = 11， 相 应 地 ， 可 以 看 成 
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WHERE 主键 列 = 主键 值 。 在 这 里 并 不 一 定 要 选择 数据 库 中 的 主键 来 当做 主 索引 键 字段 。 
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图 3-91 选择 “删除 记录 ”命令 







































































(meo - a, A | ~ ** a 
首先 检查 是 否 已 定义 变量 : | 主键 值 -| 确定 
连接 : [webconn x 取消 
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主键 值 : vRL 参数 ~| ID 
MIRE $F]: index. php | 
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图 3-92 设置 “删除 记录 ” XN 


IM 


pue 

至 此 ， 已 经 学 习 了 最 基本 的 Dreamweaver 内 置 服务 器 行为 ， 并 且 了 解 了 其 源 程 序 代码 的 
意义 。 在 后 面 各 章节 中 的 模版 系统 ， 如 用 户 管理 系统 、 留 言 管理 系统 、 新 闻 管理 系统 等 都 
将 用 到 这 些 操作 。 





第 4 e APERAS 


用 户 管理 系统 是 PHP 网 站 开发 应 用 中 常常 使 用 的 一 种 技术 。 一 个 典型 的 用 户 管理 系统 ， 
一 般 应 该 有 用 户 注册 功能 、 资 料 修改 功能 、 取 回 密码 功能 ， 以 及 用 户 注销 身份 等 功能 。 本 章 
将 前 面 介绍 的 知识 加 以 灵活 应 用 ， 在 实例 中 主要 用 到 创建 数据 库 和 数据 库 表 、 建 立 数据 源 连 
接 、 建 立 记录 集 、 创 建 各 种 动态 页 面 、 添 加 重复 区 域 来 显示 多 条 记录 、 页 面 之 间 传 递 信 息 、 
创建 导航 条 、 隐 藏 导航 条 连接 等 技巧 和 方法 。 





EL VAVEEZE ILU 


主要 掌握 以 下 知识 点 


用 户 管 理 系统 网 站 结构 的 搭建 
创建 数据 库 和 数据 库 表 
建立 数据 源 连 接 
掌握 用 户 管理 系统 中 页 面 之 间 信 息 传递 的 技巧 和 方法 
用 户 管理 系统 常用 功能 的 设计 与 实现 





管理 系统 





| Section | 
用 户 管理 系统 的 规划 


在 制作 网 站 的 时 候 ， 一 般 都 要 在 制作 之 前 设计 好 网 站 各 个 页 面 之 间 的 链接 关系 ， 绘 制 出 
系统 脉络 图 ， 以 便 后 面 整个 系统 的 开发 与 制作 。 


TL 系统 结构 设计 


“用 户 管理 系统 ”的 系统 结构 如 图 4-1 所 示 。 本 系统 主要 的 结构 分 成 用 户 登录 模块 与 找 
回 密 码 修 改 资 料 模块 两 个 部 分 ， 其 中 index. php 是 这 个 网 站 的 首页 。 


index.php 
























































| 户 登录 模块 
welcome.php 


新 用 户 注 册页 
regoster.php 


regfail.php regok.php 


找 回 密码 修改 资料 模块 


lostpassword.php userupdate.php 


showquestion.php userupdateok.php 
showqassword.php logoot.php 


图 4-1 系统 结构 


在 本 地 计算 机 设置 站 点 服务 器 ， 在 Dreamweaver CC 的 网 站 环境 除了 按 (F12、 键 来 浏览 
网 页 之 外 ， 还 可 以 在 I 下 浏览 絮 输 入 “http://localhost/member/index. php” 来 打开 用 户 系统 
的 首页 index. php， 其 中 member 为 站 点 名 。 


LEM Dum XT 


用 户 管理 系统 的 主要 结构 分 为 用 户 登 录 和 找 回 密码 修改 资料 两 个 部 分 ， 整 个 系统 共有 
12 个 页 面 ， 各 个 页 面 的 名 称 和 对 应 的 文件 名 、 功 能 如 表 4-1 所 示 。 
表 4-1 用 户 管理 系统 网 页 设计 表 


















loginfail.php 
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页 面 名 称 Jj 能 页 面 名 称 Xj 能 

index. php 实现 用 户 管理 系统 登录 功能 的 页 面 lostpassword. php. | 丢失 密码 后 进行 密码 查询 使 用 的 页 面 
welcome. php 用 户 登 录 成 功 后 显示 的 页 面 showquestion. php | 查询 密码 时 输入 提示 问题 的 页 面 
loginfail. php 用 户 登 录 失 败 后 显示 的 页 面 showpassword. php | 答对 查询 密码 问题 后 显示 的 页 面 
register php 新 用 户 用 来 注册 输入 个 人 信息 的 页 面 || userupdate. php | 修改 用 户 资料 的 页 面 

regok. php 新 用 户 注册 成 功 后 显示 的 页 userupdateok. php | 成 功 更 新 用 户 资料 后 显示 的 页 面 

regfail. php 新 用 户 注 册 失 败 后 显示 的 页 logoot. php 退出 用 户 系统 的 页 面 


























PHP-«-MySQL*Dreamweaver 动态 网 站 开发 从 入 门 到 精通 





C 创建 用 户 数据 库 


通过 对 用 户 管理 系统 的 功能 分 析 发 现 ， 这 个 数据 库 应 该 包括 注册 的 用 户 名 、 注 册 密 码 以 
及 一 些 个 人 信息 ， 如 性 别 、 年 龄 、E - mail、 电 话 等 。 所 以 在 数据 库 中 必须 包含 一 个 可 容纳 
上 述 信 息 的 表 ， 称 之 为 “用 户 信 息 表 ”。 将 数据 库 命 名 为 member， 接 下 来 要 在 MySQL 建立 
网 站 数据 库 作 为 查询 、 新 增 、 修 改 与 删除 任何 数据 的 后 端 支持 。 制 作 步 又 如 下 。 

1) 在 phpmyAdmin 中 建立 数据 库 member， 单 击 选择 o seeE 命令 ， 打 开本 地 的 “数据 
库 ” 管 理 页 面 ， 在 “新 建 数据 库 ” 文 本 框 中 输入 数据 库 的 名 称 member， 单 击 打 开 后 面 的 数 
据 库 类 型 下 拉 菜 单 ， 在 弹出 的 选择 项 中 选择 “utfg bin” 选项 ， 单 击 “ 创 建 ”按钮 ， 返 回 
“常规 设置 ”页 面 ， 在 数据 库 列 表 中 就 已 经 建立 了 member 的 数据 库 ， 如 图 4-2 所 示 。 


Abh 127.0.0.1 / 127.0.0.1 | p! x 
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phpMyAdmin 
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) 数据 库 Da QRS coHPh BSE 图 导入 aum BAs | 复制 o XH) v 更 多 


| gate toi) 趾 数据 库 
j cdcol 
3 db shop 马 新 建 数据 库 





s: 检查 权限 
检查 权限 
s: 检查 权限 
检查 权限 
s: 检查 权限 
al 检查 权限 
于 检查 权限 
al 检查 权限 
于 检查 权限 
al 检查 权限 





T. 全 选 / 全 不 选 荔 四 项 。 周 MM 





图 4-2 创建 member 数据 库 


2) 单 击 左边 的 member 数据 库 将 其 连接 上 ， 打 开 “ 新 建 数据 表 ” 页 面 ， 输 入 数据 表 名 
member,“ 字 段 数 ”文本 框 中 输入 本 数据 表 的 字段 数 为 12， 表 示 将 创建 12 个 字段 来 储存 数 
据 ， 再 单 击 “ 执 行 ”按钮 ， 切 换 到 数据 表 的 字段 属性 设置 页 面 ， 输 入 数据 域名 以 及 设置 数 
据 域 位 的 相关 数据 ， 如 图 4-3 所 示 。 

各 字段 如 表 4-2 所 示 ， 这 个 数据 表 主 要 是 记录 每 个 用 户 的 基本 数据 、 加 入 的 时 间 ， 以 








及 登入 的 账号 与 密码 。 
表 4-2 member 数据 表 
字段 名 称 字段 型 态 字段 大 小 说 明 
ID int 11 用 户 编号 














username varchar 20 用 户 账 号 



























































字段 名 称 字段 型 态 字段 大 小 说 — Hj 
password varchar 20 用 户 密码 
duestion varchar 50 找 回 密码 提示 
answer varchar 50 答案 
truename varchar 50 真实 姓名 
sex varchar 10 姓 别 
address varchar 50 地 址 
tel varchar 50 电话 
QQ varchar 20 QQ 号 码 
email varchar 50 邮箱 
authority char 1 登录 区 分 
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AA 7 | li, httpi//127.0.0-1/phpmyadmin/PMAURL-3:tbl structure.php?db-member&table-member&server-1&target-&token-e328bf345 $ D ~ È X 





(2 vs t9 
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phpMyAdmin RSE: 127.0.0.1 » (B 数据 库 : member > (fi 表 : member 
$G40e0€ L] AM ^ 8g O sa S RR X dA B SEO 时 导入 ARE S ER s 触发 器 
[diem . El # 名 字 类 型 排序 规则 属性 空 默认 E THE 
ea 7 11D int(11) 3; Æ — AUTO INCREMENT 中 修改 QUIM 分 主键 国 唯 一 六 更 多 
a 2 RUE EE 7] 2 username varchar(20) utf8 bin Sox 必修 改 回 删除 ouR- 六 更 多 
[2-3 member 3 password varchar(20) utf8 bin mx 必修 改 GN: Arpi- ?更 多 3 
Haxe -j 4 question varchar(50) utf8_bin mox EB QUE Otu- v5 
emm 5 answer  varchar(50) utf8 bin ox J Eh QE AEREE- 了 更 多 
FH j performance. schema © 6 truename varchar(50) utf8 bin Sx JEA QNS o ERR- ves 
($H phpmyadmin 7 sex varchar(10) utf8_bin 8x 中 修改 QE Rp- vE 
"d 3 i 8 address varchar(50) utf8 bin 是 NULL JEn @ 删除 六 主键 | 各 唯一 更 多 |] 
= webauth 9 tel varchar(50) utf8 bin 是 NULL 中 修改 QM c qu vE 
= 10 QQ varchar(20) utf8 bin 是 NULL < 修改 QE ocu uR- vus 
7] 11 email varchar(50) utf8 bin 是 NULL JEA QE AERD 了 更 多 
12 authority char(1) utf8 bin Sox 外 修改 加 删除 or y 95 
t DOSi zem o (AUR J 490 OMR 2R w- pA [Y 空间 
T 全 文 搜索 
B HETA 4S 关系 查看 qu 规划 表 结 构 © 追踪 表 ESTE 
\ Bt hn [4 ARG THAR O 于 过 开头 0 王 之 后 |ID ë l Hr | 
图 4-3 建立 member 数据 表 


创建 的 数据 表 有 12 个 字段 ， 读 者 在 开发 其 他 用 户 管理 系统 的 时 候 可 以 根据 采集 用 户 信 
息 的 需要 加 入 更 多 的 字段 。 


2 XE M, member 站 点 


在 Dreamweaver CC 中 创建 一 个 “用 户 管理 系统 ”网 站 站 点 member， 由 于 这 是 PHP 数据 
库 网 站 ， 因 此 必须 设置 本 机 数据 库 和 测试 服务 器 ， 主 要 的 设置 如 表 4-3 所 示 。 








表 4-3 






PHP-«*MySQL* Dreamweaver x 


站 点 设置 的 基本 参数 


态 网 站 开发 从 入 门 到 精通 














站 点 名 称 member 站 点 名 称 member 
本 机 根 目录 C; \xampp \htdocs \member MySQL 服务 器 地 址 | C: \xampp \mysql \ data \member 
测试 服务 器 C; \xampp Mitdocs 管理 账号 /密码 root/ 空 
网 站 测试 地 址 http ;//localhost/member/ 数据 库 名 称 member 

















创建 member 站 点 具体 操作 步 又 如 下 s 
1) 首先 在 C: V xampp\ htdocs 路 径 下 建立 member 文件 夹 ， 如 图 4-4 所 示 ， 本 章 所 有 
建立 的 网 页 文件 都 将 放 在 该 文件 夹 下 。 
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FEST) 
O- bo» 计算 机 » Acer(C) > xampp » htdocs » X | 好 | | £85 htdocs ^» 
; 文件 (Fi) ”编辑 (E) SEV) 工具 (T) 帮助 (H) 
组 织 ~ wed H7T 包含 到 库 中 v 共享 刻录 新 建文 件 夫 二 | 
m sm p| 各 称 修改 日 期 zem 大 小 s: 
33 最 近 访问 的 位 置 LJ Inaex.nrml ZU13/3/3U 19:29 30U Se MINL DO... 1&5 
favicon.ico 2013/3/30 19:29 图 标 8 KB [3 
x —,  &)bitnami.css 2013/4/29 1527 EBREN 3 KB 
"a me [L] applications.html 2013/12/3 21:20 ^ 360 se HTML Do... 2 KB 
cium iE apache pb2 ani.gif 2013/3/3019:20 — GIF 图 像 3 KB 
图 ER i8! apache. pb2.png 2013/3/30 19:22 — PNG El 2 KB 
D 文档 apache. pb2.gif 2013/3/30 19:29 — GIF 图 像 3 KB 
a) RENE - apache. pb.png 2013/3/3019:20 — PNG El 2 KB 
QJ sm | $8 apache pb.gif 2013/3/3019:29 — GIF 图 你 3 KB E 
Ji xampp 2014/12/7 19:58 
m 计算 机 Jj restricted 2014/12/7 19:55 
& Acer (Cj) |; phpweb 2014/12/7 20:18 x 
ca HERS (D) | L member 2014/12/7 20:20 Xi 
? Ey P| Wim 2014/12/7 19:55 x 
v J| forbidden 2014/12/7 19:55 
a E |. .mmServerScripts 2014/12/7 20:19 m 
member 修改 日 期 : 2014/12/7 20:20 
l|. xe 
Lh. A 
K|4-4 建立 站 点 文件 夹 member 
Ima . E E M. é6 M » € 人 人 cM » .内 € e^ 
2) 运行 Dreamweaver CC， 选 择 菜单 栏 中 的 “站 点 ”一 “管理 站 点 4, 打开 “管理 


站 点 ”对 话 框 ， 如 图 4-5 所 示 。 








HB, 























- 6 Ud 





导入 站 点 导入 Business Catalyst 站 点 





新 建站 点 


JRE Business Catalyst 站 点 














- 9h | 


Lm ] 




















4-5 


e 管理 站 点 » 


对 话 框 
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3) 对 话 框 的 左边 是 站 点 列表 框 ， 其 中 显示 了 所 有 已 经 定义 的 站 点 。 单 击 右 边 的 “新 
”按钮 ， 打 开 “ 站 点 设置 对 象 ”对 话 框 ， 进 行 如 下 参数 设置 ; 
e“ 站 点 名 称 ”，member。 


e。“ 本 地 站 点 文件 夹 ”: C:\xampp\htdocs\member\。 C» 
如 图 4-6 所 示 。 









版 本 控制 RCUESRU e E ick LEMRORS LERDEE RIDES 


》 ENSE 








您 可 以 在 此 处 为 Dreamweaver 站 点 选择 本 地 文件 夹 和 名 称 。 
站 点 名 称 : [member 
本 地 让 点 文件 夹 : [C:Wampp\htdocs member\ 
































| ww j| má || 














图 4-6 新 建站 点 参数 设置 
4) 单 击 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “添加 服务 器 ”按钮 国 ， 打 开 “ 基 本 ” 


选项 卡 ， 进 行 如 图 4-7 所 示 的 参数 设置 。 






















uhr 
mss [RC] 78 7] 5 
. 版 本 控 少 服务 器 名 称 : [member | 
* 高 级 设置 连接 方法 : | db fel Iz] web 3E 
服务 器 文件 来 : | C: xampp htdocs Jes 











Web URL: | nttp://127.0.0. 1/member/ 




















帮助 


















































图 4-7 设置 “基本 ”选项 卡 























ee“ 服务器 名 称 ”: member, 

o GERTE”: 本 地 /网 络 。 

e“ 服 务 絮 文件 夹 ”. C; \xampp\htdocs\ o 

e "Web URL": http://localhost/ 。 

5) 设置 后 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 ， 单 击 “ 维 护 同 


步 信息 ” 复 选 杠 ， 在 “服务 器 模型 ”下 拉 列 表 项 中 ， 选 择 PHP MySQL， 表 示 是 使 用 PHP JF 
发 的 网 页 ， 其 他 的 保持 默认 值 ， 如 图 4-8 所 示 。 


6) 单 击 “ 保 存 ”按钮 ， 返回“ 服务 器 ”设置 对 话 框 ,再 单 击 选择 “测试 ” 复 选 框 ， 









QL*Dreamweaver 动态 网 站 开发 从 入 门 到 精通 














高 级 设置 IV 维护 同步 信息 
O 保存 时 自动 将 文件 上 传 到 服务 器 
O 启用 文件 取出 功能 

区 打开 文件 之 前 取出 








取出 名 称 : 
电子 邮件 地 址 : 























”测试 服务 器 
服务 器 模型 :| PHP MySQL 
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4-8 设置 “高 级 ”选项 卡 

















您 将 在 此 位 置 选 择 承 戟 web 上 的 页 面 的 服务 器 。 此 对 话 框 的 设置 来 自 
Internet 服务 提供 商 (ISP) 或 Web 管理 员 。 








高 级 设置 O i 1 
注意 :要 开始 在 Dreamweaver 站 点 上 工作 ， 您 无 天 完成 此 步 螺 。 如 果 要 连接 到 Web HË 
dar D E 


Hepa [VI M. 





| | fit pms | 测 式 | 














图 4-9 设置 “服务 器 ”参数 

















单 击 “保存 ”按钮 ， 则 完成 站 点 的 定义 设置 。 在 Dreamweaver CC 中 就 已 经 拥有 了 刚才 
所 设置 的 站 点 member。 单 击 “ 完 成 ”按钮 ， 关闭“ 管理 站 点 ”对 话 框 ， 以 上 就 完成 了 Dre- 
amweaver CC 测试 用 户 管 理 系统 网 页 的 网 站 环境 设置 。 


COE 设置 数据 库 连接 


完成 了 站 点 的 定义 后 ， 接 下 来 就 是 用 户 系统 网 站 与 数据 库 之 间 的 连接 。 网 站 与 数据 库 的 
连接 设置 如 下 。 

1) 将 附 赠 资源 中 本 章 静 态 文件 复制 到 站 点 文件 夹 下 ， 打 开 index. php， 如 图 4-10 
所 示 。 











Dw XHA ”编辑 (E) EEV) 插入 (1 修改 (M) ERO 命令 (QQ ”站 点 (S) ”窗口 (W) ”帮助 (H) 


HR. 














二 设计 站 














| x 
EASP nymenber. php 





| 购物 中 心 | 















FIE 用 户 官 理 示 统 | 


“LG e 
Janon 














客户 留言 


CE], ^ raus: 三星 知 能 手机 ,100 万 像 末 ,支持 IF3、IE4 
MEFR FEME RSRS. 


忧 惠 价 : Y 2480 
会 员 价 : ¥ 2180 






文件 





x J| 








E olle 








[E nenber 





-| [本 地 视图 | 





联系 我 们 


特别 推荐 


与 
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[> body 























Et 
<>n) ËR [x 
Bis css ma) X . 链接 中 
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-Om Bh ”| 











[ 列表 项 目 . - 








B E EH 7% x 378v 














A^O|*t25d2e|m 











"Eensecti ons 
data 





images 


m 

m 

=i index php 

= loginfail.php 

"^", logoot.php 

= lostpassword... 

= oregfail php 

=, register. php 10KB PHP X 
= oregok php 2KB PHP X. 
= o showpassword...  4KB PHP Xi 
= showquestion...  — 4KB PHP Xj 
=, userupdate. php 9K PHP X 
= userupdateok... TKB PHP X 
=, welcome. php 3KB PHP X 

















2) 单 击 选择 菜单 栏 上 的 “窗口 ”一 “数据 库 ” 命 令 ， 打 
+” K 


图 4-10 打开 index. php 


开 “ 数 据 库 ”面板 。 在 “数据 库 ” 面 板 上 ， 单 击 选择 “ 


标 ， 并 在 打开 的 菜单 中 选择 “MySQL 连接 ”选项 ， 


所 示 。 


mymember, “MySQL 服务 器 ”名 为 localhost ， 


root， 密 码 为 空 如 图 4-12a 所 示 。 选 择 所 要 建立 连接 的 数据 库 名 称 ， 


3) Æ “MySQL 连接 ”对 话 框 中 ,输入 的 “连接 名 称 ” 为 
“用 户 名 ”为 ”图 4-11 


可 以 单 击 “ 选 取 ” 按 


如 图 4-11 


. 单 击 上 面 的 + FARES. 

















选择 MySQL 连接 


钮 ， 浏 览 MySQL 服务 器 上 的 所 有 数据 库 。 选 择 刚 导入 的 范例 数据 库 member， 具 体 的 设置 内 


容 如 图 4-12b 所 示 。 












































[at oo ee] 
连接 名 称 : mymember Cae ) 
MySQL ESZ localhost E) 
APS: root Citij 
二 | 
zB: (mm j 
SEE menber 选取 ... 
人 — —M / 
a) 
A 



























































, 
pore pr a e =) 
选取 数据 庄 : 


cdeol 
information s 

















=== 








b) 


4-12 设置 MySQL 连接 参数 


4) 单 击 “测试 ”按钮 ， 测 试 与 MySQL 数据 库 的 连接 是 否 正确 ， 如 果 正 确 ， 则 会 出 现 
一 个 如 图 4-13 所 示 的 消息 框 ， 这 表示 数据 库 连 接 设置 成 功 。 
单 击 “ 确 定 ” 按 钮 ， 则 返回 编辑 页 面 ， 在 “数据 库 ” 面 板 中 则 显示 绑 定 过 来 的 数据 库 ， 






















Dreamweaver 










M 
E (varchar 50) 
bx. 11 必需 的 ) 





连接 名 称 : 
MySQL 服务 器 : 
用 户 名 : 


em 
ID 

password (varchar 20 必需 的 ) 
Q P (varchar 20) 

question (varchar 50 必需 的 ) 
x (vi me 10 必需 的 ) 





o0 RUDSRDERME-, 





E 
$68 

Ed 
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ddd d: : 
5 
E 
3 
a 
E 
3 
8 








username (varchar 20 必需 的 ) 














mum 视图 
aye ”预存 过 程 





图 4-13 设置 成 功 图 4-14 显示 绑 定 的 数据 库 








DUM BPEGHRBRY 


ZB 3:9EARTR HP XESRUBEERS BE, EARR TERRAS, EVA TÉ 
中 显示 的 是 “会 员 登 录 ” 字 样 。 


2 登录 页 面 的 设计 


在 用 户 访 问 该 用 户 管理 系统 时 ， 首 先 要 进行 身份 验证 ， 这 个 功能 是 靠 登 录 页 面 来 实现 的 。 
所 以 登录 页 面 中 必须 有 要 求 用 户 输 入 用 户 名 和 密码 的 文本 框 ， 以 及 输入 完成 后 进行 登录 的 “ 登 
录 ” 按 钮 、 输 入 错误 后 重新 设置 用 户 名 和 密码 的 “ 重 置 ”按钮 。 详 细 的 制作 步骤 如 下 。 

1) 首先 ， 来 看 一 下 用 户 登录 系统 的 首页 设计 ， 如 图 4-15 所 示 。 














& 360 安 全 浏览 器 7.1 «mew —rnrx 
€ C/Q Yr Y http//127.00.1/member/index.php gv 
DLO | RS x IW $5 





Ned: a 
TE pe 


























首页 购物 中 心 | ARER 客户 留言 联系 我 们 
会 RS 录 0 | | 特别 推荐 F 
: 产品 说 明 : 三 星 智能 手机 ,100 万 像素 ,支持 IF WM | 
RPal | 和 五 下 技术 .手写 功能 , PRESS. 
zel | AUT: Y 2450 : 1 
会 员 价 : ¥2180 : 
TRARA AEB... : | E 
| 产品 分 类 : | 
: 联想 手提 电脑 1 
:掌上 电脑 本 书 是 一 本 关于 动态 网 站 开发 的 技术 图 书 ， 专门 为 
; 初次 接触 动态 网 站 开发 的 读者 而 写作 。 : 
数码 相机 i = 
|o Bee dix: voc (a 
o BMF 00000 会 员 价 : ¥23.8 
购物 流程 : E T RARRÉT bá 





K 4-15 用 户 登 录 系 统 首 页 
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2) index. php 页 面 是 用 户 登 录 系 统 的 首页 ， 打 开 前 面 所 创建 的 index. php 页 面 ， 输 入 网 
页 标题 “PHP 用 户 管理 系统 ”， 然 后 执行 菜单 “文件 ”一 “保存 ”命令 ， 将 网 页 标题 保存 。 


3) 执行 菜单 “修改 ”一 “页 面 属 性 ”命令 ， 
值 为 #CCCCCC， 在 “上 边 距 ” 文 本 框 中 输入 0 像 


然后 在 “背景 颜色 ”文本 框 中 输入 颜色 
素 ， 这 样 设置 的 目的 是 为 了 让 页 面 的 第 一 O) 


个 表格 能 置顶 到 上 边 ， 并 形成 一 个 灰色 底 纹 的 页 面 ， 设 置 如 图 4-16 所 示 。 





















































(me = 
分 类 外 观 (CSS) 
pon om 页 面 字体 中; T EA E S - 
| 大 小 (8): 12 ~ [x | 
[i 文本 颜色 m: E 
背景 颜色 E): [.«ccccc 
BRE MAW. 
E20: m 
左边 中 0 px 右边 距 R) 
bE): 0 下 边 距 0): 
帮助 00 Cie |C má | CERM) 
S 
图 4-16 “页 面 属性 ”对 话 杠 
4) 设置 完成 后 ， 单 击 “ 确 定 ” 按 钮 ， 进 入 “ 文 [ee =s) 


档 ” 窗 口 ， 执 行 菜单 “插入 ”一 “表格 ”命令 , 在 打 | a y, 


开 的 “表格 ”对 话 框 中 ， 在 “ 行 数 ”文本 框 中 输入 需 TT gx —] 
要 插入 表格 的 行 数 为 3， 在 “ 列 数 ”文本 框 中 输入 需 UU 0 E 


要 搬入 表格 的 列 数 为 3。 在 “表格 宽度 ”文本 框 中 输 
入 775 像素 ,“ 边 框 粗细 ”、“ 单 元 格 边 距 ”和 “单元 


格 间 距 ” 都 为 0， 如 图 4-17 所 示 。 


5) 单 击 “ 确 定 ” 按 钮 ， 这 样 就 在 “文档 ”窗口 


中 搬入 了 一 个 3 行 3 列 的 表格 。 将 鼠标 放置 在 第 





表格 中 ， 在 “属性 ”面板 中 单 击 “ 合 并 所 选单 元 格 ， 
使 用 跨度 ”按钮 图 标 咖 ， 将 第 1 行 表 格 合并 ， 再 执行 


菜单 “插入 ”一 “图 像 ” 一 “图 像 ”命令 ， 打 开 “ 
































单元 格 间距 Ol ki 
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yt 图 4-17 设置 “表格 ”属性 














择 文件 ”对 话 框 ， 在 站 点 images 文件 夹 中 选择 图 片 01. gf， 如 图 4-18 所 示 。 


6) 单 击 “确定 ”按钮 ， 就 在 表格 中 搬入 了 此 图 片 ， 将 鼠标 放置 在 第 3 行 表格 中 ， 在 








属性 ”面板 中 单 击 “ 合 并 所 选单 元 格 ， 使 用 蜂 度 ”按钮 图 标 回 ， 将 第 3 行 所 有 列表 格 合 


并 ， 再 执行 菜单 “插入 ”一 “图 像 ”一 “图 像 ”命令 ， 打 开 “ 选 择 文件 ”对 话 框 ， 在 站 点 


images 文件 夹 中 选择 图 片 05. gif, 插入 一 个 图 片 ， 
7) 插入 图 片 后 ， 选 择 插入 的 整个 表格 ,在 “ 











8) 把 光标 移 至 创建 表格 第 2 行 第 1 列 中 ,在 





效果 如 图 4-19 所 示 。 
属性 ”面板 上 “对 齐 ” 下 拉 列 表 框 中 ， 选 





择 “ 居 中 对 齐 ” 命 令 ， 让 插入 的 表格 居中 对 齐 ， 如 图 4-20 所 示 。 





“属性 ”面板 中 设置 高 度 为 456 像素 、 


度 为 179 像素 。 设 置 高 度 和 宽度 时 ,根据 背景 图 像 而 定 ， 从 “背景 ”中 选择 E cue 
文件 夹 中 的 02. gif 文件 ， 得 到 的 效果 如 图 4-21 所 示 。 



































P 
加 选择 图 像 源 文件 
i » 计算 机 » Acer(C) » xampp » htdocs » member » images ~ | 4s || £85 images P 
组 织 ” 新 建文 件 夫 &- rm e | 
| J 收 项 夫 ^ te m) gam] | 
= j RA CH e | | 
z — z: 
同 库 — = | iai 
I 三 | | tare | zs 
| 网 京 庭 组 2 OLgif 02.gif 02_01.gif 02_02.gif 03.gif 
an a s 
而 计算 机 5| 5 
Ë Acer (C) u w 
ca RERS (D) ES c os 
ca 本 地 磁盘 (Er) 04.gif 05.gif 07.gif 








文件 名 (N): 01.gif ~ [pesce C.gif*jpg jpeg; p v 


站 点 根 目录 确定 “|| me 


图 4-18 “选择 图 像 源 文件 ”对 话 框 






































T c: \apache\htdocs\menbertindez. php* - 


LG Lp 
puce Simia 














图 4-19 搬入 图 片 效 果 图 
























































属性 
EF] 表格 Awe | Xe [775 hez v| Bc) ”| 对 齐 的 | 居 中 对 齐 v) FOE m 
一 ETE 间距 GS) o — | 边框 中 0 












































uw gis 9c 





vd x 





图 4-20 设置 “居中 对 齐 ” 


9) 在 表格 的 第 2 行 第 2 列 和 第 3 列 中 ， 分 别 插入 同 站 点 images 文件 夹 中 的 图 片 03. gif 
和 04. gf， 完 成 网 页 的 结构 搭建 ， 如 图 4-22 所 示 。 

10) 单 击 第 2 行 第 1 列 单元 格 ， 然 后 再 单 击 “ 文 档 ” 窗 口上 的 碟 列 按钮 ， 在 <td > 和 
</td> 之 间 加 入 valign ="top" (表格 文字 和 图 片 的 相对 摆 放 位 置 ， 可 选 值 为 up 、middle、 
bottom) 的 命令 ， 表 示 让 鼠标 能 够 自动 地 贴 至 该 单元 格 的 最 顶部 ， 设 置 如 图 4-23 所 示 。 








0000090 0o eee 
eeoeoeoec£€69^5^* 


用 户 管理 系统 


ee@@@ 
*«e000nu 
*v«o00 















































图 
yg I veo x 646v 63 K / 2 P Unicode (UTF-8) 
图 4-21 插入 图 片 的 效果 图 


T c: wpachevht docs WnenberVindez. php* 


BP 用 应 管理 ; us g 

















产品 说 明 : 三 星 智能 手机 , 1007518, Seda. M4 
和 蓝牙 技术 .手写 功能 , 外 观 美 等 特点 。 

WEM: 2 2480 

会 员 价 : 2180 














联想 手提 电脑 








本 书 是 一 本 关于 动态 网 站 开发 的 技术 图 书 ,专门 为 | 
初次 接触 动态 网 站 开发 的 读者 而 写作 。 : 


REM: vos 
会 员 价 : 2.8 








产品 说 明 : 具有 6824 处 理 器 和 5 英寸 触 拣 屏 蔓 以 及 可 c 
HEWER S8 SE REF LAE O— REP EP REB, BE. d 
已 惠 价 : Y 10588 














图 4-22 ”完成 的 网 页 背景 效果 图 





PHP*MySQL*Dreamweaver 


T c: \apache\htdocs\menbertindez. php* 


"775" border= 
enter" 
" cellspacing 


"inages/04.qgif 


height-"456" /»«/td» " 
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产品 说 明 : 三 星 智能 手机 , 100 万 像素 ,支持 虹 3、 岂 4 
和 蓝牙 技术 .手写 功能 , 外 观 美 等 特点 。 
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图 4-23 ”设置 单元 格 的 对 齐 方式 为 最 项 部 
注意 : 


文档 工具 栏 中 包含 按钮 和 弹出 的 菜单 ， 提 供 各 种 文档 “ 窗 
和 “代码 ”视图 ) 、 各 种 查看 选项 和 一 些 常用 操作 (如 在 浏览 器 
对 选项 说 明 如 下 。 


口 视图 ” 


(如 “R 
中 预览 ) 。 


« 拆 


e "AGE". 显示 代码 视图 ， 仅 在 “文档 ”窗口 中 显示 代码 视图 。 

e "JEU. 显示 代码 视图 和 设计 视图 ， 在 “文档 ”窗口 的 一 部 分 中 显示 代码 视图 ， 而 
在 另 一 部 分 中 显示 设计 视图 。 

e “设计 ” : 显示 设计 视图 ， 仅 在 “文档 ”窗口 中 显示 设计 视图 。 

e "ERARU. 允许 为 文档 输入 一 个 标题 ， 它 将 显示 在 浏览 器 的 标题 栏 中 。 

e“; 没有 浏览 器 /检查 错误 "， 可 以 检查 跨 浏 览 器 兼容 性 。 

e“ 文 件 管理 ”: 显示 文件 管理 弹出 菜单 。 

e“ 在 浏览 器 中 预览 /调试 ": 在 浏览 器 中 预览 或 调试 文档 ， 从 弹出 菜单 中 选择 一 个 浏 
览 器 。 

e“ 刷 新 设计 视图 FS3”: 当 在 代码 视图 中 进行 更 改 后 刷新 文档 的 设计 视图 。 

e “WAAR”: 允许 为 代码 视图 和 设计 视图 设置 选项 ， 如 “标尺 ”、“ 网 格 ”、“ 文 件 

11) 单 击 “ 文 档 ” 窗 口上 的 [CE 按钮 ， a a E “设计 ”窗口 模式 ， 在 刚 创 建 


表格 的 单元 格 中 ， 执 行 菜单 “插入 ”一 “表单 ”一 
一 个 表单 。 


表单 ”外 





命令 ， 如 图 4-24 所 示 , 插入 
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文件 (7) 编辑 (F) EO) ERM ROMO 命令 (C) 站 点 (5) 窗口 (7) 帮助 00 

标签 (6)... Ctrl+E C: \Apache\htdocs\member\inder. php 

Biga) CtrltAlt+I 

BEHR (6) 


Ka m) - 若 要 在 该 页 面 上 使 用 动态 数据 : 
一 | vo is gesucnehe ier. 
RET CtrltALt+T v 2 € 
表格 对 象 A) 上 点 的 负 试 服务 器 。 

> 4. 按 加 号 0) 按钮 并 选择 记 
布局 对 象 (Y) gus 











超级 链接 P) Grat o5 

电子 邮件 链接 L) KEE A) 

命名 锚 记 OD CtrltAlttA 按钮 6) 
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注释 C 选择 ( 列表 /菜单 )(5) 
a R 文件 域 F) 


HTML 
图 像 域 1) 
模板 对 象 0) m 


晤 近 的 代码 片断 ,Q emm — — — BH 本 地 视图 v 
: | MERAH) : y 
es prine : Rejse y (à dme 


jQuery Mobile DS Mrd : EC 站 点 - members C. 


InContext Editing(I) 字段 集 G) 1 © Connections 
BENRO 标签 @) inscex 
E spry BERE D - p | 
BEURER U... spry 验证 文本 区 域 0]) [Unicode (WTP-8) loginfail php 
获取 更 多 对 象 6)... Spry 验证 复 选 框 C) D) logoot. php 
[o m.) RET 3 * 3 Spry 验证 选择 €) lostpassword... 
|o Spy 验证 密码 

coo e a spry 验证 确认 0) 

gr] tx atoa EW[ rs AGO] Spry 验证 单 渤 控 包 组 

器 站 和 下 高 只 3888 00 口 ] 








































































































图 4-24 执行 “表单 ”命令 


12) 将 鼠标 放置 在 该 表单 中 ， 执 行 菜单 “插入 ”一 “表格 ”命令 ,打开 “表格 ”对 话 
框 ,， 在 “ 行 数 ” 文 本 框 中 输入 5， 在 “ 列 数 ”文本 框 中 输入 2。 在 “表格 宽度 ”文本 框 中 输 
入 179 像素 ， 在 该 表单 中 插入 5 行 2 列 的 表格 。 单 击 并 拖 动 鼠标 ， 分 别 选择 第 1 行 、 第 2 行 
和 第 5 行 表 格 ， A “属性 ”面板 中 单 击 使 用 “合并 所 选单 元 格 ， 使 用 跨度 ”按钮 回 ， 
将 这 几 行 表格 进行 合并 。 然 后 在 表格 的 第 1 行 输入 “会 员 登 录 ”4 个 字 ， 在 第 2 行 第 1 列 中 
输入 文字 说 明 SR 在 第 2 行 第 2 列 中 执行 菜单 “插入 ”一 < 表单 一 “文本 ” 命 
令 ， 捅 入 一 个 单行 文本 域 表 单 对 象 ， 并 定义 文本 域名 为 “username”, “文本 域 ”属性 设置 
及 此 时 的 ; 效果 如 图 4-25a、4-25b 所 示 。 
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图 4-25 输入 “用 户 名 ”和 插入 “文本 域 ”的 设置 
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说 明 : 设置 文本 域 的 属性 说 明 如 下 。 

e 在 “文本 域 ” 文 本 框 中 ,为 “文本 域 ”指定 一 个 名 称 。 每 个 “文本 域 ”都 必须 有 一 
个 唯一 名 称 。 表 单 对 象 名 称 不 能 包含 空格 或 特殊 字符 ， 可 以 任意 组 合 字母 、 数 字 、 字 
符 和 下 画 线 (_) 。 请 注意 ， 为 “文本 域 ”指定 的 标签 将 存储 该 域 的 值 (输入 的 数据 ) 
的 变量 名 ， 这 是 发 送 给 服务 器 进行 处 理 的 值 。 

e“ 字 符 宽度 ”设置 域 中 最 多 可 显示 的 字符 数 。 用 “最 多 字符 数 ” 指定 在 域 中 可 输入 的 

最 多 字符 数 ， 如 果 保 留 为 空白 ， 则 输入 不 受 限 制 。“ 字 符 宽度 ”可 以 小 于 “最 多 字符 

数 ”"， 但 大 于 “最 多 字符 数 ” 的 输入 则 不 被 显示 。 

“类 型 ”用 于 指定 文本 域 是 “单行 ” “多 行 ” 还 是 “密码 ” 域 。 单 行文 本 域 只 能 显 

示 一 行文 字 ; 多 行 则 可 以 输入 多 行文 字 ， 达 到 字符 宽度 后 换行 ; 密码 文本 域 则 用 于 输 


入 密码 。 
e“ 初 始 值 ” 指 定 在 首次 载 入 表单 时 ， 域 中 显示 的 值 。 例 如 ， 通 过 包含 说 明 或 示例 值 ， 


可 以 指示 用 户 在 域 中 输入 信息 。 

e@“ 类 ”可 以 将 CSS 规则 应 用 于 对 象 。 

13) 在 第 3 行 第 1 列表 格 中 输入 文字 说 明 “ 密 码 ”， 在 第 3 行 表格 的 第 2 列 中 执行 菜单 
“搬入 ”一 “表单 ”一 “文本 ”命令 ， 插 入 密码 文本 域 表 单 对 象 ， 定 义 “ 文 本 域 ” 名 为 
password。“ 文 本 域 ”属性 设置 及 此 时 的 效果 如 图 4-26a、b 所 示 。 








属性 
O 文本 域 字符 宽度 m) [12 | 类 型 Oo Osm ë OSBP) 类) | 无 wl 
[password | 最 多 宇 符 数 | 0 Mra D | |] 多 









































到 4-26 ”密码 “文本 域 ”的 设置 


14) 选择 第 4 行 单元 格 ， 执行 菜单 “插入 ”一 “表单 ”一 “按钮 ”命令 两 次 ,插入 两 
个 按钮 ， 并 分 别 在 “属性 ”面板 中 进行 属性 变更 ， 一 个 为 登录 时 用 的 “提交 表单 ”选项 ， 
一 个 为 “ 重 设 表单 ”选项 “属性 ”的 设置 如 图 4-27a、b 所 示 。 

15) 在 第 S 行 输入 “注册 新 用 户 ” 文 本 ， 并 设置 一 个 转 到 用 户 注册 页 面 register. php 的 
链接 对 象 ， 以 方便 用 户 注册 ， 输 入 的 效果 如 图 4-28a、b 所 示 。 

16) 如 果 已 经 注册 的 用 户 忘记 了 密码 ， 还 希望 以 其 他 方式 能 够 重新 获得 密码 ， 可 以 在 
表格 的 第 4 列 中 输入 “ 找 回 密码 ”文本 ， 并 设置 一 个 转 到 密码 查询 页 面 lostpassword. php 的 
链接 对 象 ， 方 便 用 户 取 回 密码 ， 如 图 4-29a、b 所 示 。 

17) 表单 编辑 完成 后 ， 下 面 来 编辑 该 网 页 的 动态 内 容 ， 以 便 用 户 可 以 通过 该 网 页 中 表单 
的 提交 实现 登录 功能 。 打 开 “ 服 务 器 行为 ”面板 ， 单 击 该 面板 上 按钮 向 ， 执 行 菜单 “用 户 身 
份 验 证 ”一 “登录 用 户 ” 命 令 ， 如 图 4-30 所 示 ， 向 该 网 页 添加 “登录 用 户 ” 的 服务 器 行为 。 
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EE 
| 按钮 名 称 An | 登录 动作 名 提交 表单 】 OX GC) 无 v 
. Suhit OA M) 
a) 
尾 性 
| | 按钮 名 称 iB) mE 动作 局 提交 表单 (Ss】 Oxo 3C) 无 m 
Subnit? 全 重 设 表单 Q) 
b) 
4-27 设置 按钮 名 称 
尾 性 
EAN 无 v 类 | 无 v| BI iziz ss 25 标题 (I) 
En css ID() 无 wi THEE) register. php v e Biz (c) v 
EH] 单元 格 KFORU v| Xen 不 换行 (0) 口 aeo [: TUBE... 
— c 3p EMAU ~v aw| c2] #20 [0 
TÈ C: Mpache\htdocz\menber\indez. php -0x 
| RAER erus 
FRNA: CATREEA OTRE, vr, M 
METHA FEHR RSRS. 
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图 4-29 ”密码 查询 设置 
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图 4-30 添加 “登录 用 户 ” 服 务 需 行为 
18) 此 时 打开 “登录 用 户 ” 对 话 框 ， 各 项 参数 设置 如 图 4-31 所 示 。 

































































使 用 连接 验证 : mymember | 
表格 : |member - | 
用 户 名 列 : | username | 
密码 列 : | password - | 
如 果 登 录 成 功 ， 转 到 : welcome. php 浏览 ... 
转 到 前 一 个 URL (如 果 它 存在 》 
MREFA $F: loginfail. php Ene] 
基于 以 下 项 限制 访问 : 人 @ 用 户 名 和 密码 
O 用 户 名 、 密码 和 访问 级 别 
f 获取 级 别 自 :I m 
a — — —Ó 
图 4-31 “登录 用 户 ” 对 话 框 





该 对 话 框 中 各 项 设置 的 作用 如 下 。 


. 从 “从 表单 获取 输入 ”下 拉 列 表 框 中 ， 选 择 该 服务 器 行为 使 用 网 页 中 的 forml 对 象 ， 


设 定 该 用 户 登 录 服务 器 了 为 的 用 户 数据 来 源 为 表单 对 象 中 访问 者 填写 写 的 内 容 。 


e 从 “用 户 名 字段 ”下 拉 列 表 框 中 ， 选 择 文本 域 username 对 象 ， 设 定 该 用 户 登 录 服 务 


器 行为 的 用 户 名 数据 来 源 为 表单 的 username 文本 域 中 访问 者 输入 的 内 容 。 


e 从 “密码 字段 ”下 拉 列 表 框 中 ， 选 择 文本 域 password 对 象 ， 设 定 该 用 户 登 录 服 务 需 
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行为 的 密码 数据 来 源 为 表单 的 password. 文本 域 中 访问 者 输入 的 内 容 。 
e 从 “使 用 连接 验证 ”下 拉 列 表 框 中 ， 选 择 用 户 登 录 服 务 器 行为 使 用 的 数据 源 连接 对 
象 为 my member。 
e 从 “表格 ”下 拉 列 表 框 中 ， 选 择 该 用 户 登 录 服 务 器 行为 使 用 到 的 数据 库 表 对 象 为 o 
member, 
e 从 “用 户 名 列 ” 下 拉 列 表 框 中 ， 选 择 表 member 存储 用 户 名 的 字段 为 username。 
e 从 “密码 列 ” 下 拉 列 表 杠 中， 选择 表 member 存储 用 户 密码 的 字段 为 password。 
e 在 “如 果 登 录 成 功 ， 转 到 ”文本 框 中 输入 登录 成 功 后 ， 转 问 welcome. php 页 面 。 
e 在 “如 果 登 录 失 败 ， 转 到 ”文本 框 中 输入 登录 失败 后 ， 转 向 loginfail. php 页 面 。 
e 选择 “基于 以 下 项 限制 访问 ”后 面 的 “用 户 名 和 密码 ” 单 选 按钮 ， 设 定 后 面 将 根据 
用 户 的 用 户 名 、 密 码 共 同 决定 其 访问 网 页 的 权限 。 
19) GEMERA, Mii “M” HEA, RMVA, mmm neson m 
返回 到 “文档 ”窗口 。 在 “服务 需 行 为 ”面板 中 就 增加 了 一 | seme —— 
个 “登录 用 户 ” 行 为 ， 如 图 4-32 所 示 。 
20) 表单 对 象 对 应 的 “属性 ”面板 的 动作 属性 值 如 
图 4-33 所 示 , 为 <? php echo $login FormAction; ? >。 它 的 ”图 4-32 “服务 器 行为 ” 
作用 就 是 实现 用 户 登 录 功 能 ， 这 是 一 个 Dreamweaver 自动 生 
成 的 动作 代码 。 
21) 执行 菜单 “文件 ”一 “保存 ”命令 ,将 该 文档 保存 到 本 地 站 点 中 ， 完 成 网 站 的 首 
页 制作 。 


























面板 














属性 








表单 ID 动作 [<?php echo $loginFormAction; ?> D BRM v| 类 (C) | 无 
[f 方法 |P0sT x| 编码 类 型 > 





图 4-33 ”表单 对 象 对 应 的 “属性 ”面板 


Rm 登录 成 功 和 失败 | 


当 用 户 输 入 的 登录 信息 不 正确 时 ， 就 会 转 到 loginfail php 页 面 ， 显 示 登 录 失 败 的 信息 。 
如 果 用 户 输入 的 登录 信息 正确 ， 就 会 转 到 welcome. php 页 面 。 下 面 首先 来 制作 loginfail. php 
页 面 ， 详 细 制 作 步骤 如 下 。 

1) 执行 菜单 “文件 ”一 “新建” 命令 ， 在 网 站 根 目录 下 新 建 一 个 名 为 loginfail. php 的 
网 页 并 保存 。 

2) 登录 失败 页 面 设计 如 图 4-34 所 示 。 在 “文档 ” 窗 i 
HIER HEER "RE X, 在 其 对 应 的 “属性 ” 面板 上 的 登录 失败 ， 请 检查 你 填写 的 用 户 名 的 密码 是 否 正确 ? 
“链接 ”文本 框 中 输入 index. php, 将 其 设置 为 指 问 in- | aexccmexme 
dex. php 页 面 的 链接 。 

3) 执行 菜单 “文件 ”一 “保存 ”命令 ， 完 成 login- 





























图 4-34 登录 失败 页 面 
loginfail. php 
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fail. php 页 面 的 创建 。 

接 下 来 制作 welcome. php 页 面 ， 详 细 制 作 的 步骤 如 下 。 

1) 执行 菜单 “文件 ”一 “新 建 ”命令 ， 在 网 站 根 目 录 下 新 建 一 个 名 为 welcome. php 的 
网 页 并 保存 。 

2) 用 类 似 制作 登录 失败 页 面 的 方法 制作 登录 成 功 页 面 的 静态 部 分 ， 如 图 4-35 所 示 。 

3) SV AT E S a TI AET WR, 单 击 该 面板 上 四 按钮 ， 
在 弹出 的 菜单 中 ， 选 择 “ 阶 段 变 量 ” 选 项 ， 为 网 页 中 定义 一 个 阶段 变量 ， 如 图 4-36 所 示 。 
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DS 








4-35 登录 成 功 页 面 的 效果 图 图 4-36 添加 阶段 变量 








重点 说 明 : 
绑 定 面板 中 “阶段 变量 ”命令 经 常 使 用 ， 具 体 的 功能 说 明 如 下 。 
阶段 变量 提供 了 一 种 对 象 ， 通 过 这 种 对 象 ， 用 户 信息 得 以 存储 ， 并 使 该 信息 在 用 户 访问 
的 持续 时 间 中 对 应 用 程序 的 所 有 页 都 可 用 。 阶 段 变量 还 可 以 提供 一 种 超时 形式 的 安全 对 象 ， 
这 种 对 象 在 用 户 账户 长 时 间 不 活动 的 情况 下 ， 终 止 该 用 户 的 会 话 。 如 果 用 户 忘 记 从 Web 站 
点 注销 ， 这 种 对 象 还 会 释放 服务 器 内 存 和 处 理 资源 。 
4) 打开 “阶段 变量 ”对 话 框 ， 在 “名 称 ” 文 本 框 中 输入 “阶段 变量 ”的 名 称 MM_ 
username， 如 图 4-37 所 示 。 
5) 设置 完成 后 ， 单 击 该 对 话 框 中 的 “确定 ”按钮 ， 在 “文档 ”窗口 中 通过 拖 动 鼠 标 选 
择 “XXXXXX” 文 本 ， 然 后 在 “ 绑 定 ”面板 中 选择 MM_username 变量 ， 再 单 击 “ 绑 定 ” 面 
板 底部 的 “插入 ”按钮 ， 将 其 插入 到 该 “文档 ”窗口 中 设 定 的 位 置 。 插 入 完毕 ， 可 以 看 到 
“XXXXXX” 文 本 被 oru MM username| 占 位 符 代 替 ， 如 图 4-38 所 示 。 这 样 ， 就 完成 
了 这 个 显示 登录 用 户 名 “阶段 变量 ”的 添加 工作 。 
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图 4-37 “阶段 变量 ” 对 话 村 
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图 4-38 插入 后 的 效果 

重点 提示 : 设计 阶段 变量 的 目的 ， 是 在 用 户 登 录 成 功 后 ， 登 录 界 面 中 可 以 直接 显示 用 户 
的 名 字 ， 使 网 页 更 有 亲切 感 。 

6) 在 “文档 ”窗口 中 拖 动 鼠标 选中 “注销 你 的 用 户 ” 文 本 。 执 行 菜单 “窗口 ”一 
“服务 器 行为 ”一 “用 户 身份 验证 ”一 “注销 用 户 ” 命 令 ， 为 所 选中 的 文本 添加 一 个 “ 注 








销 用 户 ” 的 服务 器 行为 ， 如 图 4-39 所 示 。 
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图 4-39 “注销 用 户 ” 命 令 


7) 打开 “注销 用 户 ” 对 话 框 ， 在 该 对 话 框 中 进行 如 下 设置 。 

e“ 在 以 下 情况 下 注销 ”用 于 设置 注销 时 机 ， 本 例 选择 “ 单 击 链接 ” 单 选 按钮 ， 并 在 右 
边 的 下 拉 列 表 框 中 选择 “所 选 范围 : 注销 你 的 用 户 ”， 这 样 当 用 户 在 页 面 中 单 击 “ 注 
销 你 的 用 户 ” 时 就 执行 注销 操作 。 

e“ 在 完成 后 ， 转 到 ”文本 框 用 于 注销 后 显示 的 页 面 ， 本 例 在 右 侧 文本 框 中 输入 lo- 
goot. php ， 表 示 注 销 后 转 到 logoot php 页 面 ， 完 成 后 的 设置 如 图 4-40 所 示 。 





























EM ee rm te | e 
在 以 下 情况 下 注销 : @ 单 击 链接 :| "注销 你 的 用 户 ” -] € 
EAM (m 
| 在 完成 后 ， 转 到 : logoot. php EET NN 
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= —— 








图 4-40 设置 完成 后 的 “注销 用 户 ” 对 话 框 





8) 设置 完成 后 ， 单 击 “ 确 定 ” 按 钮 ， 关 闭 该 对 话 框 ,返回 到 “文档 ”窗口 。 在 “ 服 
务 器 行为 ”面板 中 增加 了 一 个 “注销 用 户 ” 行 为 ， 同 时 可 以 看 到 “注销 用 户 ” 链 接 文本 对 
应 的 “属性 ”面板 中 的 “链接 ”属性 值 为 <? php echo $logoutAction ? > ， 它 是 Dream- 
weaver 自动 生成 的 动作 对 象 。 

9) logoot. php 的 页 面 设计 比较 简单 ， 不 做 详细 说 明 ， 在 页 面 中 的 “这 里 ”处 指定 一 个 
链接 到 首页 index. php 就 可 以 了 ， 效 果 如 图 4-41 所 示 。 
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body? (kx) Q 100$ ~|519x 131v 1 K / 1% Unicode (UTF-B) — . 








DS 








图 4-41 注销 用 户 页 面 设 计 效 果 
10) 执行 菜单 “文件 ”一 “保存 ”命令 ， 将 该 文档 保存 到 本 地 站 点 中 。 编 辑 工作 完成 


后 ， 就 可 以 测试 该 用 户 登 录 系 统 的 执行 情况 了 。 文 档 中 的 “修改 您 的 注册 资料 ”链接 到 
userupdate. php 页 面 ， 此 页 面 将 在 后 面 的 修改 章节 中 进行 介绍 。 


LES 登录 功能 的 测试 


制作 好 一 个 系统 后 ， 需 要 测试 无 误 ， 才 能 上 传 到 服务 器 使 用 。 下 面 就 对 登录 系统 进行 如 
下 测试 。 

1) 打开 浏览 器 ， 在 地 址 栏 中 输入 http: //127.0.0. 1/memberx， 打 开 index. php 页 面 ， 
如 图 4-42 所 示 。 
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图 4-42 打开 的 网 站 首页 


2) 在 “用 户 名 ”和 “密码 ”文本 框 中 分 别 输入 用 户 名 及 密码 ， 输 入 完毕 ， 单 击 “ 登 
录 ” 按 钮 。 
3) 如 果 在 第 2 步 中 填写 的 登录 信息 是 错误 的 ， 或 者 根本 就 没有 输入 ， 则 浏览 器 就 会 转 
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到 登录 失败 页 面 loginfail. php， 显 示 登 录 失 败 信息 ， 如 图 4-43 所 示 。 
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图 4-43 登录 失败 页 面 loginfail. php 效果 





设置 的 用 户 design， 登 录 成 功 后 的 页 面 如 图 4-44 所 示 ， 其 中 显示 了 用 户 名 design, 


4) 如 果 输 入 的 用 户 名 和 密码 都 正确 ， 则 显示 登录 成 功 页 面 。 这 里 输入 的 是 前 面 数 据 库 
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图 4-44 登录 成 功 页 面 welcome. php 效果 
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5) 如 果 想 注销 用 户 ， 只 需要 单 击 “ 注 销 你 的 用 户 ” 超 链 接 即 可 。 注 销 用 户 后 ， 浏 览 需 
就 会 转 到 页 面 logoot php， 然 后 单 击 “ 这 里 ” 回 到 首页 ， 如 图 4-45 所 示 。 至 此 ， 登 录 功 能 


就 测试 完成 。 
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图 4-45 ”注销 用 户 页 面 效 果 





|_Section | 
用 户 注 册 模 块 的 设计 


用 户 登 录 系 统 是 为 数据 库 中 已 有 的 老 用 户 登 录用 的 ， 一 个 用 户 管理 系统 还 应 该 提供 新 用 
户 注册 用 的 页 面 。 对 于 新 用 户 来 说 ， 通 过 单 击 index php 页 面 上 的 “注册 新 用 户 ” 超 链接 ， 
进入 到 名 为 register. php 的 页 面 ， 在 该 页 面 中 实现 新 用 户 注册 功能 。 


用 户 注册 页 面 


register. php 页 面 主要 实现 用 户 注册 的 功能 ， 用 户 注 册 的 操作 就 是 向 member. mdb 数据 库 
的 member 表 中 添加 记录 的 操作 ， 完 成 的 页 面 如 图 4-46 所 示 。 
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图 4-46 用 户 注册 页 面 样式 





HARRERA 





1) Big UE > E dires, ERAR FL TONER T AAH register. php 的 
网 页 并 保存 。 
2) 在 Dreamweaver 中 使 用 制作 静态 网 页 的 工具 ， 完 成 如 图 4-47a、b 所 示 的 静态 部 分 ， 
这 里 要 说 明 的 是 ， 注 册 时 需要 加 入 一 个 “隐藏 域 ”并 命名 为 authority ， 设 置 默认 值 为 0, 即 S) 
所 有 的 用 户 注册 的 时 候 默 认 是 一 般 访问 用 户 。 
尾 性 


Fei pe tef 
[x] authority - iio 0 2 


















































DS 














4-47 register. php 页 面 静 态 设 计 

重点 提示 : 在 为 表单 中 的 文本 域 对 象 命名 时 ， 由 于 表单 对 象 中 的 内 容 将 被 添加 到 member 
表 中 ， 因 此 设置 表单 对 象 中 的 文本 域名 与 数据 库 中 的 相应 字段 名 相同 ， 这 样 做 的 目的 是 当 该 表 
中 的 内 容 添加 到 member 表 中 时 可 以 自动 配对 。 文 本 “密码 验证 ”对 应 的 文本 框 命名 为 pass- 
word1。 隐 藏 域 是 用 来 收集 或 发 送信 息 的 不 可 见 元 素 ， 对 于 网 页 的 访问 者 来 说 ， 隐 藏 域 是 看 不 
见 的 。 当 表单 被 提交 时 ， 隐 藏 域 就 会 将 信息 用 设置 时 定义 的 名 称 和 值 发 送 到 服务 器 上 。 

3) 还 需要 设置 一 个 验证 表单 的 动作 ， 用 来 检查 访问 者 在 表单 中 填写 的 内 容 是 否 满足 数 
据 库 中 表 member 中 字段 的 要 求 。 在 将 用 户 填 写 的 注册 资料 提交 到 服务 器 之 前 ， 首 先 对 用 户 
填写 的 资料 进行 验证 。 如 果 有 不 符合 要 求 的 信息 ， 可 以 向 访问 者 显示 错误 的 原因 ， 并 让 访问 
者 重新 输入 。 

4) 执行 菜单 “窗口 ”一 “行为 ”命令 ， 则 会 打开 “行为 ”面板 。 单 击 “ 行 为 ”面板 
中 的 由 按钮 ， 从 打开 的 行为 列表 中 选择 “检查 表单 ”命令 ， 打 开 “ 检 查 表单 ”对 话 框 ， 如 
图 4-48 所 示 。 
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图 4-48 设置 “检查 表单 ”对 话 杠 
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本 例 中 ， 设 置 username 文本 域 、password 文本 域 、passwordl 文本 域 、answer 文本 域 、 
truename 文本 域 、 address 文本 域 为 “ 值 : 必需 的 ”、 “可 接受 : 任何 东西 ”， 即 这 几 个 文本 域 
必须 填写 ， 内 容 不 限 ， 但 不 能 为 空 ; tel 文本 域 和 qq 文本 域 设置 的 验证 条 件 为 “ 值 ， 必需 
的 ”“ 可 接受 : 数字 ”， 表 示 这 2 个 文本 域 必 须 填 写 数 字 ， 不 能 为 空 ;e mail 文本 域 的 验 
证 条 件 为 “ 值 : 必需 的 ”、“ 可 接受 : 电子 邮件 ”， 表 示 该 文本 域 必须 填写 电子 邮件 地 址 ， 且 
不 能 为 空 。 

5) 设置 完成 后 ， 单 击 “确定 ”按钮 ， 完 成 对 检查 表单 的 设置 。 

6) 在 “文档 ”窗口 中 单 击 工具 栏 上 的 匡 王 按钮 ， 转 到 代码 编辑 窗口 ， 然 后 在 验证 表单 
动作 的 源 代码 中 修改 如 下 的 代码 ， 主 要 是 实现 中 文 汉化 的 功能 。 





< script type = " text/ Javascript" > 

// 宣 告 脚本 语言 为 JavaScript 

function MM, validateForm( ) | //v4.0 
if ( document. getElementById ) | 





var i, p,q,nm,test, num, min, max,errors =' ,args = MM, validateForm. arguments ; 


for (120; i< (args. length 22) ; i+ 23) | test 2 args[ i +2]; val = document. getElementById 




















(Cargs[i] ) ; 
if (val) | nm = val. name; if ( (val = val. value)! ="") | 
if (test. indexOf( isEmail )! = -1) | p= val. indexOf( @ ); 
if (p<1 Il p= = (val. length -1)) errors + = -' +nm + 需要 输入 . \n ; 
// 如 果 提 交 的 邮箱 地 址 表单 中 不 是 邮件 格式 , 则 显示 为 “需要 输入 ” 
} else if (test! = R ) | num = parseFloat( val) ; 
if (isNaN(val) ) errors + = -' +nm 4 需要 输入 数字 . \n ; 
// 如 果 提 交 的 电话 表单 中 不 是 数字 , 则 显示 为 “需要 输入 数字 ” 
if (test. indexOf( inRangé ) ! = -1) | p=test. indexOf( : ); 


min = test. substring(8,p) ; max = test. substring( p +1); 
if (num < min || max « num) errors + = —' enm t 需要 输入 数字 min 4 and + 
max + . \n ; 
// 如 果 提 交 的 QQ 表单 中 不 是 数字 , 则 显示 为 “需要 输入 数字 ” 
FE] else if (test charAt(0) = =' R ) errors + =' -' +nm+ is 需要 输入 .\n ;| 
// 如 果 提 交 的 地 址 表单 为 空 , 则 显示 为 “需要 输入 ” 
} if (errors) alert( 注册 时 出 现 如 下 错误 :\n + errors) ; 
// 如 果 出 错 将 显示 “注册 时 出 现 如 下 错误 : 
document. MM, returnValue = (errors = =" ); ! a 
- password is RERA. 


| | - passwordl is 需要 输入 . 
- truename is ZEA. 

















| [7 





























«/script > ow ise gil 
- QQ is SERA. | 
编辑 代码 完成 后 ， 单 击 工 具 栏 上 的 玲 弄 按钮， 返回 到 ners BA 
“文档 ”窗口 。 
此 时 ， 可 以 测试 一 下 执行 的 效果 ， 不 输入 相应 的 信息 ， [ we | 
然后 单 击 “ 提 交 ” 按 钮 ， 则 会 打开 一 个 警告 框 ， 如 图 4-49 


IHI 


所 示 图 4-49 “提示 错误 ” xp 








户 管理 系统 





7) 在 该 网 页 中 添加 一 个 “插入 记录 ”的 服务 器 行为 。 执 行 菜单 “窗口 ”一 “服务 器 
行为 ”命令 ， 打 开 “ 服 务 器 行为 ”面板 。 单 击 该 面板 上 办 按钮 ， 在 弹出 的 菜单 中 ， 选 择 
“插入 记录 ”命令 ， 则 会 打开 “插入 记录 ”对 话 框 ， 如 图 4-50 所 示 。 
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图 4-50 执行 “插入 记录 ”操作 


8) 在 “插入 记录 ”对 话 框 中 进行 如 下 设置 。 


e 从 “连接 ”下 拉 列 表 框 中 选择 mymember 作为 数据 源 连接 对 象 。 

e 从 “插入 表格 ”下 拉 列 表 框 中 选择 member 作为 使 用 的 数据 库 表 对 象 。 

e 在 “搬入 后 ， 转 到 ”文本 框 中 ， 设 置 当 记录 成 功 添加 到 表 member 后 转 到 regok. php 网 页 。 
e 在 对 话 框 下 半 部 分 ， 将 网 页 中 的 表单 对 象 和 数据 库 中 表 member 中 的 字段 一 一 对 应 起 


来 。 设 置 完成 后 该 对 话 框 如 图 4-51 所 示 。 
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插入 后 ， 转 到 : regok. php rum 


















































图 4-51 RE “MAWR” XS 
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9) 设置 完成 后 ， 单 击 “确定 ”按钮 ， 关 闭 该 对 话 框 ， 返 回 到 “文档 ”窗口 。 此 时 的 设 


计 样 式 如 图 4-52 所 示 。 
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mynenber. php 


Se 1G: uc 
Nu Bim: 


联系 我 们 




















目 国 国 sosx3v 








if (function exists("GetSQLValueString")) { 
function GetSüLValueString(fbtheValue, $theType, $theDefinedValue = "", $theNotDefinedValue = "") 


if (PHP VERSION < 6) [ 
$theValue = get magic quotes gpcÓ ? stripslashes($theValue) : $theValue; 


插入 记录 (forml，mymember，member) 

















图 4-52 插入 记录 后 的 效果 图 


10) 用 户 名 是 用 户 登 录 的 身份 标志 ， 用 户 名 是 不 能 重复 的 ， 所 以 在 添加 记录 之 前 , 一 
定 要 先 在 数据 库 中 判断 该 用 户 名 是 否 已 存在 ， 如 果 存 在 ， 则 不 能 进行 注册 。 在 Dreamweaver 
中 提供 了 一 个 检查 新 用 户 名 的 服务 器 行为 ， 单 击 “服务 器 行为 ”面板 上 办 按钮 ， 在 弹出 的 


菜单 中 ， 执 行 “ 用 户 身 份 验证 ”一 “检查 新 用 户 名 ”命令 ， 如 网 4-53 


所 示 。 
















Le 


SE dins 


登录 用 户 

限制 对 页 的 访问 

注销 用 户 
检查 新 用 户 名 




















B E EH eos x 395v 









if (function exists("GetSüLValueString^)) { 
Fanien GetSüLVslueString($theValue, $theType, $theDefinedValue = "* 







, $theNotDefinedValue = "") 






if (PHP VERSION < 8) [ 
$theValue = get megic quotes gpc() ? stripslashes($theValue) : $theValue: 
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图 4-53 “检查 新 用 户 名 ”命令 

















此 时 ， 会 打开 一 个 “检查 新 用 户 名 ”对 话 框 ， 在 该 对 话 框 中 进行 
e 在 “用 户 名 字段 ”下 拉 列 表 框 中 选择 username 字段 。 
e 在 “如 果 已 存在 ， 则 转 到 ”文本 框 中 [eee S ISEEE— 


























输入 regfail. php。 表 示 如 果 用 户 名 已 经 | unc eae mss 
存在 ， 则 转 到 regfal php 页 面 ， 显 示 注 | 
册 失 败 信 息 ， 该 网 页 将 在 后 面 编辑 。 — 
设置 完成 后 的 对 话 框 显示 如 图 4-54 所 示 。 图 4-54 设置 “检查 新 用 户 名 ”对 话 框 





11) 设置 完成 后 ， 单 击 该 对 话 框 中 的 “确定 ”按钮 ， 关闭 该 对 话 框 ,返回 到 “文档 ” 
窗口 。 在 “服务 器 行为 ”面板 中 ， 增 加 了 一 个 “检查 新 用 户 名 ”行为 ， 再 执行 菜单 “ 文 
件 ” 一 “保存 ”命令 ， 将 该 文档 保存 到 本 地 站 点 中 ， 完 成 本 页 的 制作 。 


SEU 注册 成 功 和 失败 


为 了 方便 用 户 登录 ， 应 该 在 regok. php 页 面 中 设置 一 个 转 到 index. php 页 面 的 文字 链接 ， 
以 方便 用 户 进行 登录 。 同 时 ， 为 了 方便 访问 者 重新 进行 注册 ， 则 应 该 在 regfail. php. 页 面 设置 
一 个 转 到 register. php 页 面 的 文字 链接 ， 以 方便 用 户 进 行 重 新 登录 。 本 节制 作 显示 注册 成 功 
和 失败 的 页 面 信息 。 

1) 执行 菜单 “文件 ”一 “新 建 ”命令 ， 在 网 站 根 目录 下 新 建 一 个 名 为 regok. php 的 网 
页 并 保存 。 

2) regok. php 页 面 如 图 4—55 所 示 。 制 作 比 较 简 单 ， 其 中 “这 里 ”文本 设置 为 指向 in- 
dex. php 页 面 的 链接 。 
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图 4-55 注册 成 功 regok. php 页 面 














3) 如 果 用 户 输入 的 注册 信息 不 正确 或 用 户 名 已 经 存在 ， 则 应 该 向 用 户 显 示 注 册 失 败 的 
信息 。 这 里 再 新 建 一 个 regfail. php 页 面 ， 该 页 面 的 设计 如 图 4-56 所 示 ， 其 中 “这 里 ”文本 
设置 为 指向 register. php 页 面 的 链接 。 
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网 4-56 注册 失败 regfail. php 页 面 


L 注册 功能 的 测试 


设计 完成 后 ， 就 可 以 测试 该 用 户 注 册 功 能 的 执行 情况 了 。 

1) 打开 浏览 器 ， 在 地 址 栏 中 输入 http: //127. 0. 0. L/member/register. php， 打 开 regis- 
ter. php 文件 ， 如 图 4-57 所 示 。 

2) 可 以 在 该 注册 页 面 中 输入 一 些 不 正确 的 信息 ， 如 漏 填 username, password 等 必 填 字 

， 或 填写 非法 的 E-mail 地 址 ， 或 在 确认 密码 时 两 次 输入 的 密码 不 一 致 ， 以 测试 网 页 中 验 
情况 。 S 息 不 正确 ， 则 浏览 器 应 该 打开 警告 框 ， 向 访问 者 显示 
错误 原因 。 如 图 4-58 所 示 是 一 个 警告 框 示例 。 

3) 在 该 注册 页 面 中 注册 一 个 已 和 存在 的 用 户 各 ， 如 输入 design 测试 新 用 户 服务 器 行为 
的 执行 情况 ， 然 后 单 击 “ 确 定 ”按钮 ， 此 时 由 于 用 户 名 已 经 存在 ， 浏 览 器 会 自动 转 到 reg- 
palpi, 如 图 4-59 所 示 ， 告 诉 访问 者 该 用 户 名 已 经 存在 。 此 时 ， 访 问 者 可 以 单 击 
这 里 ”链接 文本 ， 返 回 register. php 页面， 以 便 重 新 进行 注册 。 

4) 在 该 注册 页 面 中 填写 正确 的 注册 信息 ， 单 击 “ 确 定 ”按钮 。 由 于 这 些 注册 资料 完全 
正确 ， 而 且 这 个 用 户 名 没有 重复 ， 浏 览 器 会 转 到 regok. php 页 面 ， 向 访问 者 显示 注册 成 功 的 
信息 ， 如 图 4-60 所 示 。 此 时 ,访问 者 可 以 单 击 “这 里 ”链接 文本 ， 转 到 index php HH, 
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E 360 安 全 浏览 器 7.1 
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密码 提示 问题 : 你 最 好 的 朋友 是 ? - 


密码 提示 答案 : 























图 4-57 打开 的 测试 页 面 
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[e C/Q *r QU http://127.0.0.1/member/register.php 














注册 时 出 现 如 下 错误 : 

- username is SEA. 
- password is RSA. 
- password1 is 8A. 
- truename is ZEA. 

- email is ZEA. 

- tel is FEA. 

- QQ is SES. 

- address is 8A. 














- answer is 需要 输入 . 





QA: 

do 址 : 
密码 提示 问题 你 最 好 的 朋友 是 ? 
密码 提示 管 



































图 4-58 ”出 错 提示 
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掌上 电脑 注册 失败 ! 


数码 相机 : ”不 好 意思 ， 你 注册 的 用 户 名 已 经 被 注册 
Eme ; ”请 单 击 这 里 重新 注册 ! 
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图 4-59 注册 失败 页 面 显示 
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图 4-60 注册 成 功 页 面 


























在 MySQL 中 打开 用 户 数据 库 文件 member， 查 看 其 中 的 member 表 对 象 的 内 容 。 此 时 可 
以 看 到 ， 在 该 表 的 最 后 已 创建 了 一 条 新 记录 ， 其 中 的 数据 就 是 刚刚 在 网 页 register. php 中 提 
交 的 注册 用 户 的 信息 ， 如 图 4-61 所 示 。 
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K| 4-61 表 member 中 添加 了 一 条 新 记录 


至 此 ， 基 本 完成 了 用 户 管理 系统 中 注册 功能 的 开发 和 测试 。 在 制作 的 过 程 中 ， 可 以 根据 
制作 网 站 的 需要 适当 加 入 其 他 更 多 的 注册 文本 域 ， 也 可 以 给 需要 注册 的 文本 域名 称 部 分 添加 
星 号 ( * ) ， 提 醒 注 册 用 户 注意 。 


HEN 资料 修改 模块 的 设计 


修改 注册 用 户 资料 的 过 程 就 是 往 用 户 数据 表 中 更 新 记录 的 过 程 ， 本 节 重 点 介绍 如 何在 用 
户 管理 系统 中 实现 用 户 资料 的 修改 功能 。 


HEURES 修改 资料 页 面 


该 页 面 主 要 是 把 用 户 所 有 资料 都 列 出 ， 通 过 “更 新 记录 ”命令 实现 资料 修改 的 功能 。 
具体 的 制作 步骤 如 下 。 

1) 首先 制作 用 户 修 改 资 料 的 页 面 。 该 页 面 和 用 户 注 册页 面 的 结构 十 分 相似 ， 可 以 通过 
对 register. php 页 面 的 修改 来 快速 得 到 所 需要 的 记录 更 新 页 面 。 打 开 register. php 页 面 ， 执 行 
菜单 “文件 ”一 “另存 为 ”命令 ， 将 该 文档 另存 为 userupdate. php， 在 第 一 行 加 入 如 下 








e 









QL+Dreamweaver 


代码 : 


<? php 
session, start( ) ; 


? >// 让 session 环境 启动 
2) 执行 菜单 “窗口 ”一 “服务 器 行为 ”命令 ， 打 开 “ 服 务 器 行为 ”面板 。 在 “服务 
器 行为 ”面板 中 删除 全 部 的 服务 器 行为 并 修改 其 相应 的 文字 ， 该 页 面 修改 完成 后 如 图 4-62 
Biz o 


Tc MipachelhtdocsWmemberluserupdate.php (XHTML) 





xr 






首页 购物 中 心 | ARER | 客户 留言 
有 
| 


学 上 电脑 
数码 相机 
ERME E 
名 牌 手机 


| mine 

工 选 购 产 品 
2 .确定 订购 
3. 网 上 付款 à 
4. 填 写 信息 E E 


Ji 
<body> [A ]eu Q 100$ v749 x 511» 66 K / 2# Unicode (UTF-8) — :: 

















图 4-62 — userupdate. php 静态 页 面 
3) 执行 菜单 “窗口 ”一 “ 绑 定 ”命令 ， 打 开 “ 绑 定 ” 面 板 ， 单 击 该 面板 上 四 按钮 ， 
在 弹出 的 菜单 中 ,选择 “记录 集 (查询 ) ”选项 ， 则 会 打开 “记录 集 ” 对 话 框 。 
在 该 对 话 框 中 进行 如 下 设置 。 







































































e 在 “名 称 ” 文 本 框 中 输入 upuser 作为 
该 “记录 和 集 ” 的 名 称 。 gi STER Ce) 
e 从 “连接 ”下 拉 列 表 框 中 选择 “user 数 — =T == 
据 源 ”连接 对 象 为 mymember。 ge LÍ 
e 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 | m i 
数据 库 表 对 象 为 member。 mirer = 
。 在 “ 列 ” 单 选 按 钮 组 中 选择 “全 部 ” |" 
单 选 按 钮 。 «E[(R JFF 
。 在 “筛选 ” 栏 中 设置 记录 集 过 滤 的 条 件 | | | 





Jj UserName = 阶段 变量 / MM | User- 
name, 


完成 后 的 设置 如 图 4-63 所 示 。 





7m 
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4-63 ”设置 “记录 集 ” 对 话 村 



































动态 网 站 开发 从 入 门 到 精通 








4) 设置 完成 后 ， 单 击 该 对 话 框 上 的 “确定 ”按钮 ， 完 成 记录 集 的 绑 定 。 
5) 完成 记录 集 的 绑 定 后 ， 将 upuser 记录 集中 的 字段 绑 定 到 页 面 中 相应 的 位 置 ， 注 意 插 
入 一 个 隐藏 域 为 ID ， 设 置 在 用 户 名 字段 的 后 面 ， 如 图 4-64 所 示 。 
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* lex 

T. loginfail. php 

T logoot. php 

T5 lostpassword... 
regfail. php 
































Rl 4-64 绑 定 动态 内 容 后 的 userupdate. php 页 面 


6) 对 于 网 页 中 的 单 选 按钮 组 sex 对 象 ， 绑 定 动态 数据 可 以 按照 如 下 方法 ， 单 击 “服务 
器 行为 ”面板 上 四 按钮 ， 在 弹出 的 下 拉 荣 单 中 ， 执 行 “ 动 态 表单 元 素 ” 一 “动态 单 选 按钮 
命令 ， 设 置 动态 单 选 按钮 组 对 象 。 打 开 “ 动 态 单 选 按钮 组 ”对 话 框 。 从 “ 单 选 按钮 组 ”下 
拉 列 表 框 中 选择 forml 表单 中 的 单 选 按钮 组 sex。 单 击 “ 选 取 值 等 于 ”文本 框 后 面 的 加 按钮 ， 
从 打开 的 “动态 数据 ”对 话 框 中 选择 记录 集 upuser 中 的 sex 字段 ， 同 样 对 提问 的 问题 列表 进 

行动 态 绑 定 ， 如 图 4-65 所 示 。 


== 
PREA: | "sex” 在 表单 “fornl” | | 
选取 值 等 于 :《?Php $row upuser['sex'] ?> z | L 取消 ) 
mm 
| 























=_= 


图 4-65 设置 “动态 单 选 按钮 ”对 话 框 


7) 单 击 “ 服 务 器 行为 ”面板 上 四 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 更 新 记录 ”选项 ， 为 
网 页 添加 “更 新 记录 ”的 服务 器 行为 ， 如 图 4-66 所 示 。 

8) 打开 “更 新 记录 ”对 话 框 ， 该 对 话 框 与 “插入 记录 ”对 话 框 十 分 相似 ， 具 体 的 设置 
情况 如 图 4-67 所 示 ， 这 里 不 再 复述 。 

9) 设置 完成 后 ， 单 击 “ 确 定 ”按钮 ， 关 闭 该 对 话 框 ， 返 回 到 “文档 ”窗口 。 再 执行 菜 

















动态 网 站 开发 从 入 门 到 精通 
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LE 


| 客户 留言 联系 我 们 。 | 




















B E EE eos «o5. 




















《> rHL| RD [无 =] 类 无 ~ BI :£iEsses siio 
Bis css ID) X . 链接 由 "Og Bo, - 
页 面 属性 ... [ 列表 项 目 ... ] 























图 4-66 选择 “更 新 记录 ”选项 









































EE = A. E) 
提交 值 ， 自 : [fornt [ We jJ 
连接 : [mymenber 3 (59 
BER: [nember E (mm) 
»r FERES ip kn 









EET 
FORM. username” AENG 
FOR. password 获取 博 







Herin ter SIERA CI 
Heer M, " FORM. É nite: UA oi 


epum — 
提交 为: g& 1 1 JI V] xg 


在 更 新 后 ， 转 到 : userup dateok. php 3... 
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图 4-67 设置 “更 新 记录 ”对 话 框 


Hi 





单 “ 文 件 ” 一 “保存 ”命令 ， 将 该 文档 保存 到 本 地 站 点 中 。 

重点 提示 : 由 于 本 页 的 MM_Username 值 是 来 自 上 一 页 注册 成 功 后 的 用 户 名 值 ， 所 以 单 
独 测试 是 会 提示 出 错 的 。 要 先 登 录 后 ， 在 登录 成 功 页 面 单 击 “ 修 改 您 的 注册 资料 ” 超 链 接 
到 该 页 面 才 会 产生 效果 ， 这 在 后 面 的 测试 实例 中 将 进行 介绍 。 


OO 更 新 成 功 页面 


用 户 修改 注册 资料 成 功 后 ， 就 会 转 到 userupdateok. php。 在 该 网 页 中 ， 应 该 向 用 户 显 示 
资料 修改 成 功 的 信息 。 除 此 之 外 ， 还 应 该 考虑 两 种 情况 ， 如 果 用 户 要 继续 修改 资料 ， 则 为 其 











用 户 管 理 系统 


提供 一 个 返回 到 userupdate. php 页 面 的 超 文本 链接 ; 如 果 用 户 不 需要 修改 ， 则 为 其 提供 一 个 
转 到 用 户 登 录 页 面 index. php 页 面 的 超 文 本 链接 。 有 具体 的 制作 步 又 如 下 。 

1) 执行 菜单 “文件 ”一 “新 建 ”命令 ,在 网 站 根 目录 下 新 建 一 个 名 为 userupdateok. 
php 的 网 页 并 保存 ， 在 第 一 行 加 入 如 下 代码 : 


<? php 








session, start( ) ; 


? »//iE session 环境 启动 。 


2) 为 了 向 用 户 提供 更 加 友好 的 界面 ， 应 该 在 网 页 中 显示 用 户 修 改 的 结果 ， 以 供用 户 检 
查 修改 是 否 正确 。 首 先 应 该 定义 一 个 记录 集 ， 然 后 将 绑 定 的 记录 集 插 入 到 网 页 中 相应 的 位 
置 ， 其 方法 跟 制作 页 面 userupdate. php 的 力 法 一 样 。 e QU i 
对 象 ， 把 用 户 修改 后 的 信息 显示 在 表格 中 。 这 里 不 做 详细 说 明 ， 请 参考 前 面 一 小 节 内 容 ， 最 
终结 果 如 图 4-68 所 示 。 
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图 4-68 设计 “更 新 成 功 的 页 面 ” 


zB 测试 修改 资料 


编辑 工作 完成 后 ， 就 可 以 测试 该 修改 资料 功能 的 执行 情况 了 。 

1) 打开 浏览 器 ， 在 地 址 栏 中 输入 http://127. 0. 0. 1/member/index. php， 打 开 index. php 
文件 。 在 该 页 面 中 进行 登录 ， 登 录 成 功 后 进入 welcome. php 页 面 ， 在 welcome. php 页 面 单 击 
“修改 您 的 资料 ” 超 链接 ， 转 到 userupdate. php 页 面 ， 如 图 4-69 所 示 。 
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1. 选 购 产 品 
2. 确 定 订购 
3. 网 上 付款 
4. 填 写 信 息 
5. 签 收 产品 
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| 会 员 登 录 | 客户 留言 | 
请 用 户 认真 修改 注册 信息 ! J 
用 户 名 : design | 
Som [e 
SEED 0 0mm 请 写 密码 填写 一 致 
真实 姓名 : AAI 
# A: e mgmox 
E-mail: designem(163.com | 
Bod 81809965 
Q: 83560148 
地 od 北京 朝阳 
密码 提示 问题 : 你 最 好 的 朋友 是 人 - 
密码 提示 答案 : Ehm ] 
- 





2) 在 该 页 面 中 进 和 


图 4-69 修改 admin 用 户 注 册 资 料 


一些 修 改 ， 然 后 单 击 “提交 ”按钮 ， 将 修改 结果 发 送 到 服务 器 中 。 
用 户 记录 更 新 成 功 后 ， 浏 览 器 会 转 到 userupdateok. php 页 面 中 ， 显 示 修 改 资 料 成 功 的 信息 ， 
时 还 显示 了 该 用 户 修改 后 的 资料 信息 ， 并 提供 转 到 修改 成 功 页 Manos d j 
里 对 “真实 姓名 ”进行 了 修改 ， 单 击 “ 修 改 ” 按 钮 转 到 修改 成 功 页 


M 
同 
这 


， 效 果 如 图 4-70 所 示 。 





E 360 安 全 浏览 器 7.1 
所 CI 全 会 四 http 


/27.0.0.1 member/userupdateok.php? 





D| O| Eara 


> 








| 购物 流程 


1. 选 购 产 品 
2. 确 定 订 购 
3. 网 上 付款 
4. 填 写 信 息 
5. 签 收 产品 
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l V Jis zt 
TES imis | 
aJ iaa 
| 会 员 登 录 客户 留言 | 
修改 成 功 ! 
用 户 名 : design | 3 
So B: NER i 
密码 验证 — 请 写 密码 填写 一 
真实 姓名 : |. 
# A: egorx . 
E-mail: designemQ)163.com | 
mood 81809964 
a: (83560148 
地 H: 北京 朝阳 
密码 提示 问题 : | 你 最 好 的 朋友 是 ? ~ 
密码 提示 答案 : EIM | 





重新 修改 回 登录 页 面 























图 4-70 BURI 











$45 GREECE 


上 述 测试 结果 表明 ， 用 户 修改 资料 页 面 已 经 成 功 制作 。 


Ka 
密码 查询 模块 的 设计 


在 用 户 注册 时 ， 页 面 设 计 有 密码 提示 问题 和 答案 文本 框 ， 其 作用 是 ， 当 用 户 忘 记 密 码 
时 ， 可 以 通过 这 个 问题 和 答案 到 服务 器 中 找 回 遗 失 的 密码 。 实 现 的 方法 是 判断 用 户 提 供 的 答 
案 与 数据 库 中 答案 是 否 相 同 ， 如 果 相 同 ， 则 可 以 找 回 遗失 的 密码 。 


CS 密码 查询 页 面 


本 节 主 要 制作 密码 查询 页 面 lostpassword. php， 上 有 具 体 的 制作 步骤 如 下 。 

1) 执行 菜单 “文件 ”一 “新 建 ” 命 令 , 在 网 站 根 目 录 下 新 建 一 个 名 为 lostpass- 
word. php 的 网 页 并 保存 。lostpassword. php 页 面 是 用 来 让 用 户 提 交 所 要 查询 遗失 密码 的 用 户 
名 的 页 面 。 该 网 页 的 结构 比较 简单 ， 设 计 后 的 效果 如 图 4-71 所 示 。 
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图 4-71  lostpassword. php 页 面 





2) 在 “文档 ”窗口 中 选中 表单 对 象 ， 然 后 在 其 对 应 的 “属性 ”面板 中 ,在 “表单 名 
称 ” 文 本 框 中 输入 forml ， 在 “动作 ”文本 框 中 输入 showquestion. php 作为 该 表单 提交 的 对 
象 页 面 。 在 “方法 ”下 拉 列 表 框 中 选择 POST 作为 该 表单 的 提交 方式 ， 如 图 4-72a 所 示 。 接 
下 来 将 输入 用 户 名 的 文本 域 命名 为 inputname ， 如 图 4-72b 所 示 。 














































































PHP*MySQL-*Dreamweaver 动态 网 站 开发 从 入 门 到 精通 
mi 
到 表单 ID 动作 |showqauestion php |© 目标 四 | y| 3 0|x ~] 
= (femp | 方法 |PosT x] 编码 类 型 | x] 
a) 
尾 性 
li 文本 域 字符 宽度 WW) | | 类 型 Oge) Osgm OSBP) 26) | 无 ~] 
[inputnane | 最 多 字符 数 | Wam | 多 
禁用 加 ) 
C1Ri Q0 
b) 
图 4-72 设置 表单 提交 的 动态 属性 
重点 说 明 : 


表单 属性 设置 面板 中 的 主要 选项 作用 如 下 。 

日 在 “表单 名 称 ”文本 框 中 ， 输 入 标志 该 表单 的 唯一 名 称 。 命 名 表单 后 ， 就 可 以 使 用 
脚本 语言 引用 或 控制 该 表单 。 如 果 不 命 名 表单 ， 则 Dreamweaver 使 用 语法 forml, 
from2 、…: 生 成 一 个 名 称 ， 并 在 向 页 面 中 添加 每 个 表单 时 递增 元 的 值 。 

e 在“ 方法” 下拉 列表 框 中 ， 选 择 将 表单 数据 传输 到 服务 器 的 方法 。POST 方法 将 在 
HTTP 请 求 中 嵌入 表单 数据 。GET 方法 将 表单 数据 附加 到 请 求 该 页 面 的 URL P, EE 
认 设 置 ， 但 其 缺点 是 表单 数据 不 能 太 长 ， 所 以 本 例 选 择 POST 方法 。 

e“ 目 标 ” 下 拉 列 表 框 用 于 指定 返回 窗口 的 显示 方式 ， 各 目标 值 含义 如 下 : 
blank 在 未 命名 的 新 窗口 中 打开 目标 文档 。 

_parent 在 显示 当前 文档 的 窗口 的 父 窗口 中 打开 有 目标 文档 。 

self 在 提交 表单 所 使 用 的 窗口 中 打开 目标 文档 。 

top 在 当前 窗口 的 窗 体 内 打开 目标 文档 。 此 值 可 用 于 确保 目标 文档 占用 整个 窗口 ， 即 
使 原始 文档 显示 在 框架 中 。 

当 用 户 在 lostpassword. php 页 面 中 输入 用 户 名 ， 并 单 击 “ 提 交 ” 按 钮 后 ， 这 时 会 通过 表 
单 将 用 户 名 提交 到 showquestion. php 页 面 中 ， 该 页 面 的 作用 就 是 根据 用 户 名 从 数据 库 中 找到 
对 应 的 记录 的 提示 问题 并 显示 在 showquestion. php 页 面 中 ， 用 户 在 该 页 面 中 输入 问题 的 答 
案 。 下 面 就 制作 显示 问题 的 页 面 。 

3) 新 建 一 个 文档 。 设 置 好 网 页 属性 后 ， 输 入 网 页 标题 “查询 问题 ”， 执 行 菜单 “文件 ” 
一 “保存 ”命令 ， 将 该 文档 保存 为 showquestion. php. 

4) 在 Dreamweaver 制作 静态 网 页 ， 完 成 的 效果 如 图 4-73 所 示 。 

5) 在 “文档 ”窗口 中 选中 表单 对 象 ， 在 其 对 应 的 “属性 ”面板 中 ,“ 动 作 ” 文 本 框 中 
输入 showpassword. php 作为 该 表单 提交 的 对 象 页 面 。 在“ 方法” 下拉 列表 框 中 选择 POST E 
为 该 表单 的 提交 方式 ， 如 图 4-74a 所 示 。 接 下 来 将 输入 密码 提示 问题 答案 的 文本 域 命名 为 
inputanswer， 如 图 4-74b 所 示 。 

6) 执行 菜单 “窗口 ”一 “ 绑 定 ”命令 ， 打 开 “ 绑 定 ” 面 板 ， 单 击 该 面板 上 四 按钮 ， 
从 打开 的 菜单 中 选择 “记录 集 (查询 ) ”选项 ， 则 会 打开 “记录 集 ” 对 话 框 。 

7) 在 该 对 话 框 中 进行 如 下 设置 。 

e 在 “名 称 ” 文 本 框 中 输入 Recordsetl 作为 该 记录 集 的 名 称 。 
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4-73  showquestion. php 静态 网 页 效果 
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图 4-74 dH 





FH 














e 从 “连接 ”下 拉 列 表 框 中 选择 数据 源 连 接 对 象 为 mymember。 
e 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 member, 


e 在 “ 列 ” 栏 中 选择 “ 选 定 的 ” 单 选 按 
钮 ， 然 后 从 下 拉 列 表 框 中 选择 username 
和 question, 

。 在“ 筛选” 栏 中 ， 设 置 记录 集 过 滤 的 条 
件 为 username; = ， 表 单 变量 : input- 
name， 表 示 根 据 数 据 库 中 username F 
段 的 内 容 是 否 与 从 上 一 个 网 页 表单 中 的 
inputname 表单 对 象 所 传递 过 来 的 信息 
完全 一 致 ， 来 过 滤 记 录 对 象 。 

完成 后 的 设置 如 图 4-75 所 示 。 

8) 设置 完成 后 ， 单 击 该 对 话 框 上 的 “ 确 
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图 4-75 ”设置 “记录 集 ” 对 话 框 

















按钮 ， 关 闭 该 对 话 框 。 返 回 到 “文档 ”和 窗口 。 


9) 将 Recordsetl 记录 集中 的 question 字段 绑 定 到 页 面 中 相应 的 位 置 ， 如 图 4-76 所 示 。 





















动态 网 站 开发 从 入 门 到 精通 




















|| 购物 流程 | i --x i 


1 选 购 产品 :法 用 户 名 不 存在 : N 
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图 4-76 JETE 


10) 执行 菜单 “插入 ”一 “表单 ”一 “隐藏 域 ”命令 ， 在 表单 中 搬入 一 个 表单 隐藏 
域 ， 然 后 将 该 隐藏 域 的 名 称 设 置 为 username。 

11) 选中 该 隐藏 域 ， 转 到 “ 绑 定 ”面板 ， 将 Recordsetl 记录 集中 的 username FRIE 
到 该 表单 隐藏 域 中 ， 如 图 4-77 所 示 。 

重点 提示 : 当 用 户 输入 的 用 户 名 不 存在 时 ， 即 记录 集 Recordsetl 为 空 时 ， 就 会 导致 该 页 
面 不 能 正常 显示 ， 这 就 需要 设置 隐藏 区 域 。 

12) 在 “文档 ”窗口 中 选中 当 用 户 输 入 用 户 名 存在 时 显示 的 内 容 即 整 个 表单 ， 然 后 单 
击 “ 服 务 器 行为 ”面板 上 四 按钮 ， 在 弹出 的 菜单 中 ， 执 行 “显示 区 域 ”一 “如 果 记 录 集 不 
为 空 则 显示 区 域 ”命令 ， 则 打开 “如 果 记 录 集 不 为 空 则 显示 区 域 ” 对 话 框 ， 在 该 对 话 框 中 
选择 记录 集 对 象 为 Recordsetl 。 这 样 只 有 当 记 录 集 Recordsetl 不 为 空 时 ， 才 显示 出 来 。 设 置 
完成 后 ， 单 击 “ 确 定 ”按钮 ， 如 图 4-78 所 示 。 关 闭 该 对 话 框 ， 返 回 到 “文档 ”窗口 。 































































































帮助 00 | 
| MRAR rem 
记录 集 : [Recordse | G 
|| 格式 ; Xx = 记录 集 : [Recordseti | | = 
| 代码 ;<php echo $row Recordseti[ usery | | — 
图 4-77 username 字段 绑 定 到 表单 隐藏 域 图 4-78 “如 果 记 录 集 不 为 空 则 显示 区 域 ” 对 话 框 























13) 在 网 页 中 编辑 显示 用 户 名 不 存在 时 的 文本 “该 用 户 名 不 存在 !”， 并 为 这 些 内 容 设 
置 一 个 “如 果 记 录 集 为 空 则 显示 区 域 ”隐藏 区 域 服务 器 行为 ， 这 样 当 记录 和 集 Recordsetl 为 空 
时 ， 显 示 这 些 文本 ， 完 成 后 的 网 页 如 图 4-79 所 示 。 
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4-79 设置 隐藏 区 域 


[SD 完善 密码 查询 功能 


当 用 户 在 showquestion. php 页 面 中 输入 答案 ， 单 击 “ 提 交 ” 按 钮 后 ， 服 务 右 就 会 把 用 户 
名 和 密码 提示 问题 答案 提交 到 showpassword. php 页 面 中 。 

下 面 介绍 如 何 设计 该 页 面 ， 具 体制 作 步 又 如 下 。 

1) 执行 菜单 “文件 ”一 “新 建 ” 命 令 ， 在 网 站 根 目 录 下 新 建 一 个 名 为 showpassword. 
php 的 网 页 并 保存 。 

2) 在 Dreamweaver 中 使 用 提供 的 制作 静态 网 页 的 工具 ， 完 成 如 图 4-80 所 示 的 静态 
部 分 。 
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1. 选 购 产 品 
2. 确 定 订购 
3. 网 上 付款 
4. 填 写 信息 
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图 4-80  showpassword. php 静态 设计 









QL*Dreamweaver 动态 网 站 开发 从 入 门 到 精通 





3) 执行 菜单 “窗口 ”一 “ 绑 定 ”命令 ， 打 开 “ 绑 定 ” 面 板 ， 单 击 该 面板 上 四 按钮 ， 
在 弹出 的 菜单 中 选择 “记录 集 (查询 ) ”选项 ， 则 会 打开 “记录 集 ” 对 话 框 。 

4) 在 该 对 话 框 中 进行 如 下 设置 。 

o 在 “名 称 ” 文 本 框 中 输入 Recordsetl 作为 该 记录 集 的 名 称 。 

o 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数据 源 连接 对 象 mymember。 

。 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 member, 

e 在 “ 列 ” 栏 中 选择 “ 选 定 的 ” 单 选 按钮 ， 然 后 选择 字段 列表 框 中 的 username, pass- 
word 和 answer 等 3 个 字段 就 行 了 。 

e 在 “筛选 ” 栏 中 设置 记录 集 过 滤 的 条 件 : answer 为 = ， 表 单 变量 为 inputanswer， 表 示 
根据 数据 库 中 answer 字段 的 内 容 是 否 与 从 上 一 个 网 页 表单 中 的 inputanswer 表单 对 象 
传递 所 过 来 的 信息 是 否 完全 一 致 来 过 滤 记 录 对 象 。 

完成 的 设置 情况 如 图 4-81 所 示 。 
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4-81 设置 “记录 集 ” 对 话 相 
5) 单 击 “ 确 定 ” 按 钮 ， 关 闭 该 对 话 框 ， 返回 到 “文档 ”窗口 。 
6) 将 记录 集中 username 和 password 两 个 字段 分 别 添加 到 网 页 中 ， 如 图 4-82 所 示 。 
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FK 4-82 加 入 的 记录 集 效 果 





用 户 管 理 系 统 








7) 同样 需要 根据 记录 集 Recordsetl 是 否 为 空 ， 为 该 网 页 中 的 内 容 设置 隐藏 区 域 的 服务 
器 行为 。 在 “文档 ”窗口 中 ,选中 当 用 户 输入 密码 提示 问题 答案 正确 时 显示 的 内 容 ， 然 后 
单 击 “ 服 务 器 行为 ”面板 上 四 按钮 ， 在 弹出 的 菜单 中 ， 执 行 “显示 区 域 ” 一 “如 果 记 录 集 
不 为 空 则 显示 区 域 ”命令 ， 打 开 “ 如 果 记 录 集 不 为 空 则 显示 区 域 ” 对 话 框 ， 在 该 对 话 框 中 
选择 记录 集 对 象 为 Recordsetl 。 这 样 只 有 当 记 录 集 Recordsetl 不 为 空 时 ， 才 显示 出 来 ， 如 
图 4-83 所 示 。 设 置 完成 后 ， 单 击 “ 确 定 ” 按 钮 ， 关闭 该 对 话 框 ， 返回 到 “文档 ”窗口 。 

8) 在 网 页 中 选择 当 用 户 输入 密码 提示 问题 答案 不 正确 时 显示 的 内 容 ， 并 为 这 些 内 容 设 
置 一 个 “如 果 记 录 集 为 空 则 显示 区 域 ”隐藏 区 域 服务 器 行为 ， 这 样 当 记 录 集 Recordsetl 为 空 
时 ， 显 示 这 些 文本 ， 如 图 4-84 所 示 。 





















































fas [Ex 如 果 记 录入 为 裤 则 显示 
记录 集 - [Recordsetl zi [确定 记录 集 - [Recordzetl | 
取消 
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图 4-83 “如 果 记 录 集 不 为 空 则 显示 区 域 ” 对 话 框 ”图 4-84 “如 果 记 录 集 为 空 则 显示 区 域 ”对 话 忆 
9) 完成 后 的 网 页 如 图 4-85 所 示 。 执 行 菜单 “文件 ”一 “保存 ”命令 ， 将 该 文档 保存 
到 本 地 站 点 中 。 
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图 4-85 完成 后 的 网 页 效果 图 


So 测试 密码 查询 功能 


开发 完成 后 ， 就 可 以 测试 密码 查询 功能 的 执行 情况 了 。 








D 9 o o « 


EREA SIN. 


1) 打开 浏览 器 ， 在 地 址 栏 中 输入 http://127. 0. 0. L/member/index. php, JJF index. php 
文件 。 单 击 该 页 面 中 的 “ 找 回 密码 ” 超 文本 链接 ， 如 图 4-86 所 示 的 页 面 。 
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本 书 是 一 本 关于 动态 网 站 开发 的 技术 图 书 ,专门 为 : 
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图 4-86 输入 要 查询 的 用 户 名 

2) 当 用 户 进 入 密码 查询 页 面 lostpassword. php 后 ， 输 入 并 向 服务 需 提 交 自 己 注册 的 用 户 

名 信息 。 当 输入 不 存在 的 用 户 名 ， 并 单 击 “ 提 交 ” 按 钮 ， 则 会 转 到 showquestion. php 页 面 ， 
该 页 面 显示 出 用 户 名 不 存在 的 错误 信息 ， 如 图 4-87 所 示 。 
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掌上 电脑 : 查询 问题 
数码 相机 : 该 用 户 名 不 存在 ! 























图 4-87 输入 的 用 户 名 不 存在 
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3) 如 果 输 入 一 个 数据 库 中 已 经 存在 的 用 户 名 ， 然 后 单 击 “ 提 交 ” 按 钮 。 浏 览 器 会 自动 
转 到 showquestion. php 页 面 ， 如 图 4-88 所 示 。 下 面 就 应 该 在 showquestion. php 输入 密码 提示 
可 题 答 案 ， 测 试 showquestion. php 网 页 的 执行 情况 。 
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1. 选 购 产 品 
2. 确 定 订购 
3. 网 上 付款 
4. 填 写 信息 














图 4-88 showqeustion. php 网 页 效果 图 
4) 在 这 里 可 以 先 输入 一 个 错误 的 答案 ， 检 查 showpassword. php 中 是 否 能 够 显示 密码 提 
示 问 题 的 答案 不 正确 时 的 错误 信息 ， 如 图 4-89 所 示 。 
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数码 相机 , 对 不 起 您 输入 的 管 案 不 正确 ， 请 单 击 这 里 重新 输入 ! 


























SR 























5) 如 果 在 showquestion. php 网 页 中 输入 正确 的 答案 ， 并 单 击 “ 提 交 ” 按 钮 后 ,浏览 器 





就 会 转 到 showpassword. php 页 面 ， 并 显示 出 该 用 户 的 密码 ， 如 图 4-90 所 示 。 
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图 4-90  showpassword. php 页 面 


6) 上 述 测 试 结果 表明 ， 密 码 查 询 系 统 已 经 成 功 制作 。 


至 此 ， 用 户 管理 系统 的 常用 功能 都 已 经 设计 完成 并 测试 成 功 ,设计 者 如 果 需 要 将 其 应 用 
到 其 他 的 网 站 上 ， 只 需要 与 设计 的 页 面 配 合 ， 修 改 一 些 相关 的 文字 说 明 及 背景 效果 ， 就 可 以 


完成 用 户 管理 系统 的 制作 。 





第 5 章 “” 新 闻 发 布 系统 


新 闻 发 布 系统 是 常见 的 动态 网 站 系统 ， 多 用 于 政府 单位 、 教 育 单位 或 企业 网 站 。 新 闻 发 
布 系统 的 作用 就 是 在 网 上 传播 信息 ， 通 过 对 新 闻 的 不 断 更 新 ， 让 用 户 及 时 了 解 行业 信息 、 企 
业 状 况 。 所 以 新 闻 发 布 系统 中 所 涉及 的 主要 操作 就 是 访问 者 的 新 闻 查 询 功 能 和 系统 管理 员 对 
新 闻 的 新 增 、 修 改 、 删 除 功 能 ， 使 用 PHP 实现 这 些 功 能 相对 比较 简单 。 





EL VAVEEZE ILU 


主要 掌握 以 下 知识 点 


新 闻 发 布 系统 网 站 结构 的 整体 设计 

新 闻 系 统 数 据 库 的 规划 

新 闻 发 布 系统 前 台新 闻 发 布 功能 页 面 的 制作 
新 闻 发 布 系统 分 类 功能 的 设计 

新 闻 发 布 系统 后 台新 增 、 修 改 、 删 除 功能 









PHP-«*MySQL*Dreamweaver x 


系统 的 整体 设计 规划 








网 站 的 新 闻 发 布 系统 ， 在 技术 上 主要 体现 为 如 何 显示 新 闻 内 容 ， 以 及 对 新 闻 及 新 闻 分 类 
的 修改 和 删除 。 一 个 完整 的 新 闻 发 布 系统 共 分 为 两 大 部 分 ， 一 个 是 访问 者 访问 新 闻 的 动态 网 
页 部 分 ， 另 一 个 是 管理 者 对 新 闻 进 行 编辑 的 动态 网 页 部 分 。 新 闻 发 布 系统 的 结构 图 如 图 5-1 


所 示 。 














访问 者 页 
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newscontent.php 



































admin login.php 








admin.php 





type add.php || type upd.php || type del.php || news add.php| | news upd.php || news del.php 


Kl 5-1 


新 闻 发 布 系统 结构 图 


本 系统 共有 11 个 页 面 ， 各 页 面 的 文件 名 称 与 功能 如 表 5-1 所 示 。 


表 S-1 新 闻 发 布 系统 开发 网 页 设计 表 

























































































需要 制作 的 主要 页 面 页 面 名 称 切 ”能 
新 闻 首页 indes php 显示 新 闻 分 类 和 最 新 新 闻 页 面 
新 闻 分 类 页 面 bsp p 显示 新 闻 分 类 中 的 新 闻 标题 页 面 
新 闻 内 容 页 面 — 显示 新 闻 内 容 页 面 
后 台 管 理 入 口 页 面 "mW 管理 者 登录 入口 页 面 
后 台 管理 主页 面 iain Bhip 对 新 闻 进 行 管理 的 主要 页 面 
新 增 新 闻 页 面 news add php 增加 新 闻 的 页 面 
修改 新 闻 页 面 wp 修改 新 闻 的 页 面 
删除 新 闻 页 面 edel Ph 删除 新 闻 的 页 面 
新 增 新 闻 分 类 页 面 Gpe adi ghp 增加 新 闻 分 类 的 页 面 
修改 新 闻 分 类 页 面 iype op php 修改 新 闻 分 类 的 页 面 
删除 新 闻 分 类 页 面 pede vip 删除 新 闻 分 类 的 页 面 








SUL Ómmii x x 


在 本 地 站 点 上 建立 站 点 文件 夹 news， 将 要 制作 的 新 闻 发 布 系统 文件 夹 和 文件 建立 如 


图 5-2 所 示 。 





态 网 站 开发 从 入 门 到 精通 
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f E) 
Orl Lo» 计算 机 » Acer(C) > xampp » htdocs » news » -| 好 | | ŻE news P 
; HA ”编辑 (E) EEV) IR(T) ”帮助 (H) 
HR v 包含 到 库 中 共享 ~ 刻录 ”新 建文 件 夫 &- Uude 
» yr 收藏 夫 E 名 称 修改 日 期 xm 大 小 
jJ: .mmServerScripts 2015/1/16 10:23 文件 夫 
RE |» .notes 2015/1/16 10:23 xxm 
点 admin 2015/1/16 10:23 文件 夫 
b 网 REA | |» Connections 2015/1/16 10:23 文件 夫 
|: data 2015/1/16 10:23 b 
4 计算 机 = 上 images 2015/1/16 10:23 文件 夫 
可 Acer (C) | L] index.php 2015/1/16 10:29 PHP 文件 
| ^is Acer 国 newscontent.php 2015/1/16 10:22 PHP 文件 4 
b c 本 地 磁盘 (D:) Li type.php 2015/1/16 10:24 PHP 文件 
» cz 本 地 磁盘 (E:) 
4 Cin Rif | 
b M DOUGLAS-PC m 
p jM PC-20141030EJVK adi) m 上 
] 9 个 对 象 
~ == J 














图 5-2 站 点 规划 文件 夹 和 文件 


PME 页 面 美工 设计 


新 闻 发 布 系统 主要 起 到 了 宣传 的 作用 ， 实 例 中 在 色调 上 选择 蓝 色 和 绿色 作为 主 色 调 。 由 
于 本 书 主要 讲述 使 用 Dreamweaver 开发 PHP 的 方法 ， 所 以 网 页 的 美工 设计 相对 比较 简单 ， 新 
闻 首 页 index. php 效果 如 图 5-3 所 示 。 


E 360 安 全 浏览 器 7.1 «se|wi—nmx., 
€|d t4 Yr U http//127.0.0.1/news/ Bv 
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| 最 新 新 闻 AFR 发 介 š 联系 我 们 











国内 新 闻 最 新 新 闻 : 记录 1 到 2 (总 共 2 


i B 加 入 时 间 
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K 5-3 新闻 首 页 index. php 效果 图 












o o e 


QL*Dreamweaver 有 


上 有 ”数据库 设 计 与 连接 


制作 一 个 新 闻 发 布 系统 ， 首 先 要 设计 一 个 储存 新 闻 内 容 、 管 理 员 账 号 和 密码 的 数据 库 文 
件 ， 方 便 管理 人 员 对 新 闻 数 据 信 息 进行 管理 和 完善 。 


5.2 新 闻 数 据 库 设计 


新 闻 发 布 系统 需要 一 个 用 来 存储 新 闻 标 题 tile 和 新 闻 内 容 content 的 新 闻 信 息 表 ， 还 
建立 一 个 新 闻 分 类 表 和 一 个 管理 信息 表 ， 分 别 命名 为 news 、newstype 、admin 数据 表 。 人 制作 
的 步骤 如 下 。 

1) 在 phpmyAdmin 中 建立 数据 库 news, ful; o 数据 库 命 令 打开 本 地 的 “数据 库 ” 管 理 页 
面 ， 在“ 新建 数据 库 ” 文 本 框 中 输入 数据 库 的 名 称 news， 单 击 后 面 的 数据 库 类 型 下 拉 菜 单 ， 
在 弹出 的 选择 项 中 选择 utf8_bin 选项 ， 单 击 “ 创 建 ” 按 钮 ， 返 回 “ 常 规 设置 ”页 面 ， 在 数 
据 库 列表 中 就 已 经 建立 了 news 的 数据 库 ， 如 图 5-4 所 示 。 


 360z:$ 315838 7.1 « FM| t|- |n| x 














€A ft * | © |http://127.0.0.1/phpmyadmin/#PMAURL-14:index.php?db=&table=&server=1&target=&token=4f14d R E |v 


A 127.0.0.1 / 127.0.0.1 | php x 


phpMyAdmin - CRA: 127.0.0.1 j l 3 
G 数据 库 E SQL  & 状态 s RP B 导出 B SA ARE l 复制 p) aR v m$ |j 






















CENIE CD 数据 库 服务 尖 
f. cdcol 


= 服务 器 连接 排序 规则 @ :| utf8_bin -l - 服务 器 : 127.0.0.1 via TCP/IP 
* 服务 器 类 型 : MySQL 
* 服务 器 版 本 : 5.6.14 - MySQL Community 
Server (GPL) 
外 观 设置 协议 版 本 : 10 


， 用 户 : root@localhost 





FH 3 information schema 

Ha member 

(4:2. mysql 

FH news 

de performance schema 
本 phpmyadmin 













































































"3 phpweb & 语言 -Language 图 :| 中 文 - Chinese simplified X | “服务 器 字符 集 : UTF-8 Unicode (utf8) | 
@Ha test 49 主题 : pmahomme |r. | | 
Ha webauth ] 
t. - $825 [v] 网 站 服务 器 

Jp 更 多 设置 . Mou 4.7 (Win32) OpenSSL/1.0.1e 
PHP/5.5.6 











， 数 据 库 客户 端 版 本 : rp mysqlnd 
5.0.11-dev - 20120503 - $ld: 
40933630edef551dfaca7 1298a83fad8d03dt 
$ 


* PHP 扩展 : mysqli 图 




















she HA ~ | : 


4 — " — - E E m 











图 5-4 创建 news 数据 库 


2) 单 击 左边 的 news 数据 库 将 其 连接 上 ， 打 开 “ 新 建 数据 表 ” 页 面 ， 分 别 输入 数据 表 
名 news, newstype 和 admin ， 即 创建 3 个 数据 表 。 创 建 的 news 数据 表 如 图 5-5 所 示 。 
输入 数据 域名 以 及 设置 数据 域 位 的 相关 数据 ， 数 据 表 news 的 字段 说 明 如 表 5-2 所 示 。 
















































































































































(e 360 安 全 浏览 器 7.1 
€| € | fk * || http//127.00.1/phpmyadmin/£PMAURL-17:tbl structure b-ne 
pp |  -WLLIXLZULLALLLLLMNM ES 
tas [] 浏览 M 结构 名 SQL à € Emm B Sh m) SA ^ Bf OER v 更 多 
| (最 近 使 用 的 表 ) .… z| *5 Ax 类 型 排序 规则 属性 空 SUA Mh 操作 
7j 1 news id int(20) 否 无 AUTO INCREMENT .修改 Q WI ,网 主键 了 更 多 
Ha cdcol E z 
ea ioformation schiera 7] 2 news title varchar(50) utf8 bin 否 无 < 修改 QNM 2ER 52 
GEHI member F] 3 news type varchar(20) utf8 bin 否 无 2 修改 QW R 也 更 多 
"4 mysql 4 news content text utf8 bin 是 NULL ,/f QW 2ER 也 更 多 | 
pee 7] 5 news date ^ date LEE: 2 Èi ONE pR vEZ F 
GHE admin 7] 6 news author varchar(20) utf8 bin 是 NULL p E QNM D ER vss 
+- | news 
EHG newstype t 回 全 选 。 xwIe HIWA 修改 Q M 2 xà më- gal E 空间 
ŒH} performance schema (p 全 文 搜索 
ed B 打印 预览 p 关系 查看 局 规划 未 结构 加 © EBRD DUZH 
EH phpweb een 
G-A test 性 添加 |1 | 个 字段 @ 于 表 结 尾 O 于 表 开头 © 于 之 后 | news_id -| (执行 
ŒH webauth + 索引 [| 
| 信息 | — - 一 一 —— 
已 用 空间 Row statistics 
数据 208 字 节 格式 动态 
索引 2 KB 排序 规则 utf8 bin E 
图 5-5 创建 的 news 数据 表 
表 5-2 新 闻 数 据 表 news 
意 x 字段 名 称 数据 类 型 字段 大 小 必 填 字段 
主题 编号 news id INTEGER 20 是 
新 闻 标 题 news_title VARCHAR 50 是 
新 闻 分 类 编号 news type VARCHAR 20 是 
新 闻 内 容 Dews_content TEXT 
新 闻 加 入 时 间 news, date DATE 是 
编辑 者 news author VARCHAR 20 














3) 创建 newstype 数据 表 ， 用 于 储存 新 闻 分 类 用 ， 输 入 数据 域名 以 及 设置 数据 域 位 的 相 
关 数 据 ， 如 图 5-6 所 示 。 
newstype 数据 表 的 字段 及 说 明 如 表 5-3 所 示 。 


表 5-3 新 闻 分 类 数据 表 newstype 








mox 字段 名 称 数据 类 型 字段 大 小 必 填 字段 
主题 编号 type_id INTEGER 11 是 
新 闻 分 类 type_name VARCHAR 50 是 














4) 创建 admin 数据 表 ， 用 于 后 台 管 理 者 登录 验证 用 ， 输 入 数据 域名 以 及 设置 数据 域 位 
的 相关 数据 ， 如 图 5-7 所 示 。 









发 从 入 门 到 精通 
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€| IE 会 *!| e http://127.0.0.1/phpmyadmin/*PMAURL-19:tbl structure.php?db-news&table-newstype&server-1&t R € vj 

























































































phpMyAdmin 
f$aecce 








| (最 近 使 用 的 表 ) … 











司 newstype 
performance_schema 


Bru) 
FH phpmyadmin 
FH) phpweb 

FH test 

ŒH webauth 





IL" y jih 127.0.0.1/phpmyadmin/sP!. x 


HEE: news "图 Æ: admin 





I 小 


phpMyAdmin 127.0.0.1 s 者 数据 库 : news " 园 去 : newstype 
RB OHG E] 浏览 M an E SQL | à E EA B S BSA S Bf DER v 更 多 
| (最 近 使 用 的 表 ) ~ # 名 字 类 型 排序 规则 属性 空 默认 额外 操作 
E 1 type id int(11) 否 无 AUTO INCREMENT 修改 QI D xd 了 更 多 
2 t Aem 7] 2 type name varchar(50) utf8 general ci 否 无 < 修改 QW ,人 主键 这 更 多 
a E 
SERE iris t Dež zem MARO 2 k o Q WS xs më- gzl 图 空间 
de ps m 全 文 搜索 
EH news 
js & 打印 预览 qe 关系 查看 M make © 追踪 表 移动 字段 
1 zer am| | 个 字段 @ 于 表 结尾 © FAFA © 于 之 后 | ype id [v] (Mfr) 
news Ce 
pi pam rS 
FH i) performance schema | 信息 | 
$a phpmyadmin [Td 
Ha) phpweb 
po test 已 用 空间 Row statistics 
Bi ig wobauth ET so 字 节 格式 动态 
索引 2 KB 排序 规则 utf8 general ci 
总 计 2.1 KB 行 数 2 
行 长 度 40 x 
行 大 小 1,064 字 节 
下 一 个 自 增值 4 
创建 时 间 2011-07-08 15:51:30 - 
图 5-6  newstype 数据 表 
E 360 安 全 浏览 器 7.1 « ms |t |—|mi| x 


€ 他 会 * | e http://127.0.0.1/phpmyadmin/*PMAURL-21:tbl structure.php?db-news&table-admin&server-1&targ [2 G6 |* 











[] 浏览 M 结构 E SQL A EE X AA BS ES 
# 名 字 类 型 排序 规则 E ZR UO 
性 认 
F 1 这 int(11) 8 






























































入 | 4 操作 ©ÉR 
操作 


v 更 多 


无 ”AUTO_INCREMENT 修改 @ Wl 2 iep- 
vē% 














7] 2 username varchar(50) utf8_general_ci Sx Q^ Q MS E iu i — 
vē 
F) 3 password varchar(50) utf8_general_ci 否 无 必修 改 QW za gytE— 1 
YES 3 
t Dk zem pda J ER OQ MS o xs më- £s 司空 间 
(y 全 文 搜索 
B 打印 预览 唱 关系 查看 电 规划 表 结 构 图 x 追踪 表 移动 字段 
性 添加 |1 ”| 个 字段 @@ TRAE © FAFA © 于 之 后 | id 了 (执行 ) 
+ 索引 
| 信息 | 
| 信息 :| 
已 用 空间 Row statistics 
数据 20 字 节 格式 动态 
索引 2 KB 排序 规则 utf8 general ci 
总 计 2 KB 


行 数 1 














图 5-7 创建 admin 数据 表 
admin 数据 表 的 字段 及 说 明 如 表 5-4 所 示 。 


新 闻 发 布 系统 





表 5-4 管理 信息 数据 表 admin 


























意 X 字段 名 称 数据 类 型 字段 大 小 必 填 字段 
主题 编号 id 动 编号 长 整 型 
用 户 名 username 文本 50 是 
密码 password 文本 50 是 

















在 创建 上 述 3 个 数据 表 时 ， 涉 及 新 闻 保 存 时 的 时 间 保 存 问题 。 使 用 PHP 实现 获取 系统 
默认 即时 时 间 ， 可 以 使 用 两 种 方法 ， 一 种 是 在 网 页 中 用 PHP 的 date( ) 和 time( ) 函数 实现 ， 
另 一 种 是 直接 获取 MySQL 数据 库 中 的 NoD( ) 时间。 考虑 到 因为 后 期 数据 量 大 需要 减少 服务 
器 的 工作 量 ， 优 先 采 用 在 网 页 使 用 PHP 获取 时 间 的 方法 ， 具 体 的 实现 方法 在 新 增 新 闻 页 面 
的 设计 时 会 讲 到 。 


在 Dreamweaver CC 中 创建 一 个 “新 闻 发 布 系统 ”网 站 站 点 news， 由 于 这 是 PHP 数据 库 
网 站 ， 因 此 必须 设置 本 机 数据 库 和 测试 服务 器 。 主 要 的 设置 如 表 5-5 所 示 。 



































表 5-5 站 点 设置 的 基本 参数 
站 点 名 称 news 站 点 名 称 news 
本 机 根 目 录 C; \xampp \htdocs news MySQL 服务 器 地 址 C: \xampp \mysqdl\data\news 
测试 服务 器 C:\xampp \htdocs\ 管理 账号 /密码 root/ 空 
网 站 测试 地 址 http://localhost/ news/ 数据 库 名称 news 
创建 news 站 点 具体 操作 步骤 如 下 。 


1) 首先 在 C:\xampp\htdocs 路 径 下 建立 news 文件 夹 ， 如 图 5-8 所 示 ， 本 章 所 有 建立 的 
网 页 文件 都 将 放 在 该 文件 夹 下 。 
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[eI 
EO- L » 计算 机 » Acer(C) > xampp » htdocs » - [4] | £82 htdocs ^» 
; 文件 (有 ”编辑 (E) EEV) 工具 (T) 帮助 (H) 
组 织 " E 包含 到 库 中 Y 共享 刻录 新 建文 件 夫 ~- E G 
|: Creative Cloud ^ Lj index.php |» forbidden 
i FE = | index.html ND mmServerScripts 
m su 园 faviconico 
3g 最 后 访 问 的 位 置 it | bitnami.css 
| Japplications.html 
as apache_pb2_ani.gif 
Bun 3 iE apache pb2.png 
E B P iE apache pb2.gif 
E» iE apache pb.png 
E Sa F iE apache pb.gif 
图 REFE mb 
中 音乐 L restricted 
E O phpweb 
B 计算 机 | |, news | 
ü& Acer (C:) |; member 
ca HERS (D) Ji img 
news 修改 日 期 : 2014/12/8 10:42 
Hox 
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建立 站 点 文件 夹 news 









PHP-*MySQL-*Dreamweaver 动态 网 站 开发 从 入 门 到 精通 


2) 运行 Dreamweaver CC， 选 择 菜 单 栏 中 的 “站 点 ”一 “管理 站 点 ”命令 ,打开 “管理 
站 点 ”对 话 框 ， 如 图 5-9 所 示 。 




















Dreamweaver 
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图 5-9 “管理 站 点 ”对 话 框 





3) 对 话 框 的 左边 是 站 点 列表 框 ， 其 中 显示 了 所 有 已 经 定义 的 站 点 。 单 击 右边 的 “新 
建 ”按钮 ， 打 开 “ 站 点 设置 对 象 ”对 话 框 ， 进 行 如 下 参数 设置 。 
e“ 站 点 名 称 ”: news。 
e "Zu yh X E36" : C:\xampp\htdocs news 
如 图 5-10 所 示 。 






Dreamweaver 站 点 是 网 站 中 使 用 的 所 有 文件 和 资源 的 集合 。Dreamweaver 
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您 可 以 在 此 处 为 Dreamweaver 站 点 选择 本 地 文件 夹 和 名 称 。 | 




















站 点 名 称 : [news il 
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帮助 bz 















































图 $-10 建立 news 站 点 


4) 单 击 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “ 添 加 服务 器 ”按钮 国 ， 打 开 “ 基 本 ” 
选项 卡 ， 进 行 如 图 5-11 所 示 的 参数 设置 。 

se“ 服务 器 名 称 ”: news, 

e“ 连 接 方法 ”: 本 地 /网 络 。 

o “IRIA”: C; \xampp \htdocs\。 

e "Web URL": http:// 127.0. 0. 1/7 news/, 

5) 设置 后 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 ， 选 择 “ 维 护 同 
步 信 息 ” 复 选 框 ,在 “服务 器 模型 ”下 拉 列 表 项 中 选择 PHP MySQL 来 表示 是 使 用 PHP 开发 





新 闻 发 布 系统 





的 网 页 ， 其 他 的 保持 默认 值 ， 如 图 5-12 所 示 。 
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图 5-12 设置 “高 级 ”选项 卡 





























6) 单 击 “ 保 存 ”按钮 ,返回 “服务 器 ”设置 对 话 杠 ,再 选择 “测试 ” 复 选 框 ， 如 图 5-13 
所 示 。 





您 将 在 此 位 置 选择 承载 web 上 的 页 面 的 服务 器 。 此 对 话 框 的 设置 来 自 
Internet 服务 提供 商 (ISP) 或 Web 管理 员 。 
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图 5-13 设置 “服务 器 ”参数 

































QL*Dreamweaver 动态 网 站 开发 从 入 门 到 精通 





单 击 “保存 ”按钮 ， 则 完成 站 点 的 定义 设置 。 在 Dreamweaver CC 中 就 已 经 拥有 了 刚才 
所 设置 的 站 点 news。 单 击 “ 完 成 ”按钮 ， 关 闭 “ 管 理 站 点 ”对 话 框 ， 这 样 就 完成 了 Dream- 
weaver CC 测试 新 闻 发 布 系统 网 页 的 网 站 环境 设置 。 


SPARE 设置 数据 库 连 接 
完成 了 站 点 的 定义 后 ， 接 下 来 就 是 新 闻 发 布 系统 网 站 与 数据 库 之 间 的 连接 。 网 站 与 数据 


库 的 连接 设置 如 下 。 
1) 将 附 赠 资 源 中 本 章 文 件 复制 到 站 点 文件 夹 下 ， 打 开 index. php, WE 5-14 所 示 。 
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5-14 打开 网 站 首页 index. php 


2) 单 击 选择 菜单 栏 上 的 “窗口 ”一 “数据 库 ” 命 令 ， 打 
开 “ 数 据 库 ”面板 。 在 “数据 库 ” 面 板 ， 单 击 选择 “+ ”网 
标 ， 并 在 打开 的 菜单 中 选择 “MySQL 连接 ”选项 ， 如 图 5-15 |» 
所 示 。 : 

3) Æ "MySQL 连接 ”对 话 框 中 ， 输 入 “连接 名 称 ” 为 
news, “MySQL 服务 器 ”名 为 localhost, “用 户 名 ”为 root， 密 图 5-15 选择 “MySQL 连接 ” 
码 为 admin， 如 图 5-16a 所 示 。 选 择 所 要 建立 连接 的 数据 库 名 称 ， 可 以 单 击 “选取 ”按钮 ， 
浏览 MySQL 服务 器 上 的 所 有 数据 库 。 选 择 刚 建立 的 范例 数据 库 news， 具 体 的 设置 内 容 如 
图 5-16b 所 示 。 

4) 单 击 “ 测 试 ”按钮 测试 与 MySQL 数据 库 的 连接 是 否 正 确 ， 如 果 正 确 则 会 出 现 一 个 
消息 框 ， 如 图 5-17 所 示 ， 表 示 数 据 库 连接 设置 成 功 了 。 





为 该 文件 创建 站 点 。 

选择 一 种 立 档 类 型 。 
设置 站 点 的 WESS ii. 
单 击 上 面 的 + 按钮 创建 和 连接。 
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图 5-16 设置 “MySQL 连接 ”参数 


























单 击 “确定 ”按钮 ,返回 编辑 页 面 ， 在“ 数据库 ”面板 中 显示 绑 定 过 来 的 数据 库 ， 如 
图 5-18 所 示 。 


(MySQL 








| 连接 名 称 : 
MySQL 服务 器 : ， 
用 户 名 : 

密码 : 

数据 库 : 















































图 5-17 设置 成 功 图 5-18 绑 定 的 数据 库 
































系统 页 面 设计 


新 闻 发 布 系统 前 台 部 分 主要 有 3 个 动态 页 面 ， 分 别 是 新 闻 主 页 面 index. php， 新 闻 分 类 
页 面 type. php， 新 闻 内 容 页 面 newscontent. php. 





SE 新 闻 发 布 系统 首页 设计 


在 本 小 节 中 主要 介绍 新 闻 发 布 系 统 的 主页 面 index. php 的 制作 。index. php 页 面 主要 有 显 
示 最 新 新 闻 的 标题 、 加 入 时 间 、 显 示 新 闻 分 类 、 单 击 新 闻 中 的 分 类 进入 分 类 子 页 面 查看 新 闻 
等 功能 。 制 作 的 步骤 如 下 。 

1) 打开 刚刚 创建 的 index. php 页 面 ， 输 入 网 页 标题 “新 闻 首 页 ”， 执 行 菜单 栏 “ 文 件 ” 
一 “保存 ”命令 ， 将 网 页 保存 。 

2) 用 鼠标 单 击 创建 表格 的 第 1 行 单元 格 , 输入 文字 “新 闻 分 类 ”， 接 下 来 用 “ 绑 定 ” 
标签 ， 将 网 页 所 需要 的 新 闻 分 类 数据 字段 绑 定 到 网 页 中 。index php 这 个 页 面 使 用 的 数据 表 
是 news 和 newstype， 单 击 “ 应 用 程序 ”面板 中 “ 绑 定 ”标签 上 的 由 按钮 ， 在 弹出 的 菜单 中 
选择 “记录 集 (查询 )” 选 项 ， 在 该 对 话 框 中 进行 如 下 设置 。 

e 在 “名 称 ” 文 本 框 中 输入 Recordsetl 作为 该 记录 集 的 名 称 。 

e 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数 据 源 连接 对 象 news, 















动态 网 站 开发 从 入 门 到 精通 





e 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 newstype。 
e 在 “ 列 ” 栏 中 先 选择 “全 部 ” 单 选 按钮 。 
完成 的 设置 情况 如 图 5-19 所 示 。 



























































Ei | 
ir. RERETEEETM | Cem) 
连接 : news -| Exa | -m 

| 表格 : newstyp x| | === 

3:0 全 部 O 选 定 的 | E 
pe [ 
type nam 
|... - 
VRL 参数 
中 排序 :无 可 [升序 | 























KI 5-19 “记录 集 ” 对话 框 














3) 绑 定 记录 集 后 ， 将 记录 集 的 相关 字段 插入 至 index. php 网 页 的 适当 位 置 ， 如 图 5-20 
所 示 。 





动 CAxampp\htdocs\news\index.php* 
news. php 





PHP 新 闻 系 统 














< 四 |> 
bap — table — tr — td w tr td  tebl tr td Fo [IE div D p EH 85x31» 





























| 5-20 ”将 相应 字段 插入 至 index. php 网 页 中 














4) 由 于 要 在 index. php 这 个 页 面 中 显示 数据 库 中 所 有 新 闻 分 类 的 标题 ， 而 目前 的 设 定 
只 会 显示 数据 库 的 第 一 条 数据 ， 因 此 需要 加 入 “服务 器 行为 ”中 的 “重复 区 域 ” 的 设置 ， 
选择 |Recordsetl. type name] 所 在 的 行 ， 如 图 5-21 所 示 。 

5) 单 击 “ 应 用 程序 ”面板 群 组 中 “服务 器 行为 ”面板 中 的 由 按钮 ， 在 弹出 的 菜单 中 ， 
选择 “重复 区 域 ”命令 ， 在 打开 的 “重复 区 域 ”对 话 框 中 ， 选 中 “所 有 记录 ” 单 选 按钮 ， 
如 图 5-22 所 示 。 

6) 单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 重复 的 区 域 左上 角 出 现 了 一 
个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设置 。 

















[Recordseti. type name] 


选择 要 重复 显示 的 一 列 





Kl 5-21 





7) 除了 显示 网 站 中 所 有 新 闻 分 类 标题 外 ， 
来 实现 详细 内 容 的 阅读 。 为 了 实现 这 个 功能 ， 首 先 要 选取 编辑 页 面 中 的 新 闻 分 类 标题 字段 ， 





如 图 5-23 所 示 。 
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设置 “重复 区 域 ”对 话 框 
还 要 提供 访问 者 感 兴趣 的 新 闻 分 类 标题 链接 


图 5-22 





8) 在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 “ 浏 览 文件 ”图 标 ， 在 弹出 的 


“选择 文件 ”对 话 框 中 ， 选 择 用 来 显示 详细 记录 信息 的 页 面 type. php, 设置 如 图 5-24 所 示 。 
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K 5-23 选择 新 闻 分 类 标题 


5-04 选择 链接 文件 


9) 以 上 操作 ， 只 涉及 单纯 的 超级 链接 ， 并 没有 附带 URL 参数 ， 因 此 要 单 击 “确定 ” 
按钮 ， 并 设置 超级 链接 要 附带 的 URL 参数 的 名 称 与 值 为 type. php? id = <? php echo $row_ 
type_id ]; ? >， 


如 图 5-25 所 示 。 
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5-25 “参数 和 动态 数据 ”对 话 框 








10) 单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 主 页 面 index. php 中 新 闻 分 类 的 制作 已 经 完成 ， 
最 新 的 新 闻 显 示 页 面 设 计 效 果 如 图 5-26 所 示 。 

11) 单 击 “ 应 用 程序 ”面板 群 组 中 的 “ 绑 定 ”面板 上 的 由 按钮 ， 在 弹出 的 菜单 中 选择 
“记录 集 (查询 ) ”命令 ， 在 弹出 的 “记录 集 ” 对 话 框 中 进行 如 下 设置 。 











PHP-*MySQL-*Dreamweaver 动态 网 站 开发 从 入 门 到 精通 
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Kd 5-26 新 闻 页 面 设 计 效 果 图 


o 在 “名 称 ”文本 框 中 输入 Rel 作为 该 记录 集 的 名 称 。 

e 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数 据 源 连 接 对 象 news。 

e。 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 news。 
e 在 “ 列 ” 栏 中 选择 “全 部 ” 单 选 按钮 。 

e“ 排 序 ” 设 置 为 news_id 降序 方式 。 

完成 的 设置 情况 如 图 5-27 所 示 。 
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连接 : |news 




























































































图 5-27 设置 “记录 集 ” 对 话 框 
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12) 绑 定 “记录 集 ” 后 ， 将 记录 集 的 字段 插入 至 index. php 网 页 的 适当 位 置 。 

13) 由 于 要 在 index. php 这 个 页 面 显 示 数 据 库 中 部 分 新 闻 的 信息 ， 而 目前 的 设 定 只 会 显 
示 数 据 库 的 第 一 条 数据 ， 因 此 ， 需 要 加 入 “服务 器 行为 ”面板 中 的 “重复 区 域 ”命令 。 单 
击 选择 index. php 页 面 中 的 最 新 新 闻 标 题记 录 表 格 ， 如 图 5-28 所 示 。 

14) 单 击 “ 应 用 程序 ”面板 群 组 中 “服务 器 行为 ”面板 上 的 由 按钮 ， 在 弹出 的 菜单 中 
选择 “重复 区 域 ”命令 ， 在 弹出 的 “重复 区 域 ” 对 话 框 中 ， 选 择 要 重复 的 记录 条 数 (例如 
10 条 ) ， 如 图 5-29 所 示 。 
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5-28 单 击 选择 最 新 新 闻 标 题记 录 表 格 








15) 单 击 “确定 ”按钮 ， 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 重复 的 区 域 左上 角 出 现 
了 一 个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设 定 。 

16) 最 新 新 闻 这 个 功能 ， 除 了 显示 网 站 中 部 分 新 闻 外 ， 还 要 提供 访问 者 感 兴趣 的 新 闻 
标题 链接 至 详细 内 容 来 阅读 。 首 先 选 取 文字 “查看 ” ， 如 图 5-30 所 示 。 


Oo a 























图 5-29 选择 一 次 可 以 显示 的 记录 数 图 5$-30 选择 新 闻 标 题 “ 查 看 ” 


17) 在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 “浏览 文件 ”图 标 ， 在 弹出 的 “选择 
文件 ”对 话 框 中 ， 选 择 用 来 显示 详细 记录 信息 的 页 面 newscontent. php， 设 置 如 图 5-31 所 示 。 
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5-31 选择 链接 文件 
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18) 单 击 “ 确 定 ” 按 钮 ,设置 超级 链接 要 附带 的 URL 参数 的 名 称 与 值 newscontent php? 
news id = <?php echo $row_Rel[ news id ]; ? >。 将 参数 名 称 命名 为 news_id， 如 图 5-32 
所 示 。 
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图 5-32 “动态 数据 ”属性 设置 
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19) 当 记 录 集 超过 一 页 ， 就 必须 有 “上 一 页 ”、“ 下 一 E 
页 ”等 按钮 或 文字 ， 让 访问 者 可 以 翻 页 ， 这 就 是 “记录 集 导 A T aum 
航 条 ”的 功能 。“ 记 录 集 导航 条 ”按钮 位 于 “插入 ”工具 栏 B srame 
的 “数据 ”中 ， 因 此 将 “插入 ”工具 栏 由 “常用 ”切换 成 加 me 
“数据 ”类 型 ， 单 击 “ 记 录 集 导航 条 ”| 国 | 工 具 按钮 ， 如 图 5-33 p mem 
所 示 。 这 里 要 说 明 的 是 CC 版 本 中 也 需要 安装 扩展 才 会 有 此 操 ” 田 " mum 


作 选 项 ， 也 可 以 通过 “服务 器 行为 ”中 的 “记录 集 分 页 ” 实 。 EIE 


1B. 显示 记录 计数 F 


I 




















TT 











现 分 页 的 操作 。 pne 
20) 在 打开 的 “记录 集 导航 条 ”对 话 框 中 ， 选 取 要 导航 eomm a 











条 的 记录 集 以 及 导航 条 的 显示 方式 “文本 ”， 然 后 单 击 “ 确 pus aa 洗 择 “记录 集 导 航 条 ” 
定 ” 按 钮 回 到 编辑 页 面 ， 会 发 现 页 面 出 现 该 记录 集 的 导航 
条 ， 如 图 5-34 所 示 。 
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图 5-34 添加 “记录 集 导 航 条 ”页 面 


21) 如 果 和 希望 看 到 总 共有 多 少 记 录 ， 当 前 记录 是 第 几 条 ,那么 必须 插入 “记录 集 导 航 
状态 ” ， 在 “ 捅 入 ”工具 栏 的 “数据 ”类 型 中 ,， 单 击 “ 显 示 记 录 计 数 ” 工 具 按钮 [ 喇 ， 在 弹 
出 的 快捷 菜单 中 ， 选 取 要 导航 状态 的 记录 集 为 Rel, ， 然 后 单 击 “ 确 定 ”按钮 回 到 编辑 页 面 ， 
会 发 现 页 面 出 现 该 记录 集 的 导航 状态 ， 如 图 5-35 所 示 。 
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图 5-35 添加 计数 器 

22) index. php 这 个 页 面 需 要 加 入 查询 功能 ， wasa | 车 可 
这 样 新 闻 发 布 系统 才 不 会 因 日 后 数据 太 多 而 有 不 易 图 5_36 查询 主题 设计 
访问 的 情形 发 生 ， 设 计 如 图 5-36 所 示 。 

重点 提示 : 利用 表单 及 相关 的 表单 组 件 来 制作 利用 关键 词 查询 数据 的 功能 ， 需 要 注意 如 
下 操作 。 

e 图 5-36 所 示 的 内 容 都 在 一 个 表单 之 中 。 

e@“ 查 询 主题 ”后 面 的 文本 框 的 命名 为 keyword, 

@ “查询 ”按钮 为 一 个 提交 表单 按钮 。 

23) 在 此 要 将 之 前 建立 的 记录 集 Rel 做 一 下 更 改 ， 打 开 “ 记 录 集 ”对 话 框 ， 并 进入 
“高 级 ”设置 ， 在 原 有 的 SQL 语法 中 ， 加 入 一 段 查 询 功 能 的 语法 : 

where news title like %". $keyword."% 
那么 ， 以 前 的 SQL 语句 将 变 成 如 图 5-37 所 示 。 
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SQL: SELECT * z 
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WHERE news title like ^X". $keyword. “% 
ORDER BY news id DESC 
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图 5-37 修改 SQL 语句 












QL:-Dreamweaver 


动态 网 站 开发 从 入 门 到 精通 





重点 提示 : 其 中 lik 是 模糊 查询 的 运算 子 ，% 
示 关 键 词 。 


表示 任意 字符 ， 而 keyword 是 个 变量 ， 表 


24) 切换 到 代码 设计 窗口 RE Rel 记录 集 相 应 的 代码 并 加 入 代码 : 


$keyword = $_POST [ keyword ] ; 
图 5-38 所 示 ， 完 成 设置 。 


// 定 义 keyword 为 表单 中 " keyword" 的 请 求 变量 如 





$ CAxampp\htdocs\news\index.php* 


[ENSkeyword=$_POST [keyword]; 
if (1function exists("GetSQLValueString")) { 
function GetSQLValueString($theValue, $theType, $theDefinedValue = "", 
$theNotDefinedValue = "") 


{ 
if (PHP_VERSION < 6) { 





$theValue 


$theValue = get magic quotes gpc() ? stripslashes($theValue) : 


} 


$theValue = function exists("mysql real escape string") ? 


mysql real escape string(StheValue) 


: mysql escape string($theValue); 





switch (StheType) { 




















医 











25) 以 上 的 设置 完成 后 ， 


index. php 系统 主 


5-38 加 入 代码 
面 就 有 查询 功能 了 ， 先 在 数据 库 中 加 入 两 


条 新 闻 数 据 ， 可 以 按 下 《Fl12》 键 至 浏览 器 测 E 下 是 否 能 正确 地 查询 。 首 先 index. php 页 


面 会 





显示 所 有 网 站 中 的 新 闻 分 类 主题 和 最 新 新 闻 标题 ， 如 图 5-39 所 示 。 
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图 5- 


26) 然后 在 关键 词 中 输入 “测试 ”并 单 击 “查询 ”按钮 ， 结 果 会 发 现 页面 中 的 记录 显 
这 样 查询 功能 


示 “ 测 试 ” 所 发 表 的 最 新 新 闻 主 题 ， 








39 ”主页 面 浏览 效果 





就 已 经 完成 了 ， 效 果 如 图 5-40 所 示 。 
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图 5-40 测试 查询 效果 





SS 新 闻 分 类 页 面 设计 


新 闻 分 类 页 面 type. php 用 于 显示 每 个 新 闻 分 类 的 页 面 ， 当 访问 者 单 击 index. php 页 面 中 
的 任何 一 个 新 闻 分 类 标题 时 就 会 打开 相应 的 新 闻 分 类 页 面 ， 新 闻 分 类 页 面 设 计 效 果 如 
图 5-41 所 示 。 
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图 5-41 新 闻 分 类 页 面 效 果 
详细 的 操作 步骤 说 明 如 下 。 
1) 执行 菜单 “文件 ”一 “新 建 ”命令 创建 新 页 面 ， 输 入 网 页 标题 “新 闻 分 类 ”， 执 行 
菜单 “文件 ”一 “保存 ”命令 ， 在 站 点 news 文件 夹 中 将 该 文档 保存 为 type. php。 
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2) 新 闻 分 类 页 面 和 首页 面 中 的 静态 页 面 设 计 差 不 多 ， 在 此 不 做 详细 说 明 。 

3) type. php 这 个 页 面 主要 是 显示 所 有 新 闻 分 类 标题 的 数据 ， 所 使 用 的 数据 表 是 news, 
单 击 “ 绑 定 ” 面 板 中 的 “增加 ”上 的 四 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 记 录 集 (查询 )” 
选项 ， 在 打开 的 “记录 集 ” 对 话 框 中 进行 如 下 设置 。 

o 在 “名 称 ” 文 本 框 中 输入 Recordsetl 作为 该 记录 集 的 名 称 。 

e 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数 据 源 连 接 对 象 news。 

e 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 news。 

e 在 “ 列 ” 栏 中 选择 “全 部 ” 单 选 按钮 。 

e 设置 “筛选 ”的 条 件 为 : news id = URL 参数 : id, 

e 设置 “排序 ”方法 为 以 news_id 升序 。 

再 单 击 “ 确 定 ”按钮 后 ， 就 完成 设 定 了 ， 如 图 5-42 所 示 。 


(zas all N 











名 称 : Recordset 1 



























































K| 5-42 设置 “记录 集 ” 对 话 框 


4) 绑 定 记录 集 后 ， 将 记录 集 的 字段 插入 至 type. php 网 页 中 的 适当 位 置 ， 如 图 5-43 
所 示 。 
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图 片上 传 网 络 开发 个 人 简介 | 网 上 留言 

































































图 5-43 ”记录 集 字 上 段 插入 至 type. php 网 页 中 
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5) 为 了 显示 所 有 记录 ， 需 要 加 入 “服务 器 行为 ”面板 中 的 “重复 区 域 ” 命 令 。 单 击 
type. php 页 面 中 需要 重复 的 表格 ， 如 图 5-44 所 示 。 
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[SERERE quomdenzews | — 5,7 O a O 
K| 5-44 单 击 选择 要 重复 显示 的 表格 

6) 单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 器 行为 ”面板 上 的 办 按钮 ， 在 弹出 的 菜单 
中 ， 选 择 “ 重 复 区 域 ” 命 令 ， 打 开 “ 重 复 区 域 ” 对 话 框 ， 设 定 一 页 显示 的 数据 为 10 条 ， 如 
图 5-45 所 示 。 
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图 5-45 ”选择 一 次 可 以 显示 的 记录 数 


7) 单 击 “ 确 定 ” 按 钮 ， 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 重复 的 区 域 左上 角 出 现 了 
一 个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设置 。 

8) 在 “插入 ” 栏 的 “数据 ”类 型 中 ， 单 击 | 如 工具 按钮 ， 打 开 “ 记 录 和 集 导航 条 ”对 话 
框 ， 在 打开 的 对 话 框 中 ， 选 取 Recordsetl 记录 和 集 以 及 导航 条 的 显示 方式 为 “文本 ”， 会 发 现 
页 面 出 现 该 记录 集 的 导航 条 ， 如 图 5-46 所 示 。 
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图 5-46 添加 “记录 集 导航 条 ” 


9) 在 “插入 ” 栏 的 “数据 ”类 型 中 ， 单 击 嘲 工具 按钮 ， 在 弹出 的 菜单 中 ， 选 取 要 导 
航 状 态 的 记录 集 为 Recordsetl ， 然 后 单 击 “确定 ”按钮 回 到 编辑 页 面 ， 会 发 现 页 面 出 现 该 记 
录 集 的 导航 状态 ， 如 图 5-47 所 示 。 

10) 选取 文字 “详细 内 容 ”， 在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 “浏览 
文件 ”图 标 ， 在 弹出 的 “选择 文件 ”对 话 框 中 ,选择 用 来 显示 详细 记录 信息 的 页 面 news- 
content. php， 设 置 如 图 5-48 所 示 。 

11) 单 击 “确定 ”按钮 , 设置 超级 链接 要 附带 的 URL 参数 的 名 称 与 值 newscon- 
tent. php? news, id = < ? php echo $row_Recordsetl [ news. id ]; ? > 。 将 参数 名 称 命 名 为 
news_id， 如 图 5-49 所 示 。 

12) 加 入 显示 区 域 的 设 定 。 首 先 选取 记录 集 有 数据 时 要 显示 的 数据 表格 ， 如 图 5-50 
所 示 。 
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图 5-47 添加 “记录 集 导航 状态 ” 
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图 $-48 选择 链接 文件 
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图 5-49 “参数 ”和 “动态 数据 ” ot 
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图 $-50 选择 要 显示 的 表格 





13) 单 击 “应 用 程序 ”面板 中 “服务 器 行为 ”标签 上 的 办 按钮， 在 弹出 的 下 拉 菜 单 中 
选择 “显示 区 域 / 如 果 记 录 集 不 为 空 则 显示 区 域 ”选项 ， 打 开 “ 如 果 记 录 集 不 为 空 则 显示 区 

















域 ” 对 话 框 ， 在 “记录 集 ” 中 选择 Recordsetl 再 单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 会 发 现 
先前 所 选取 要 显示 的 区 域 左 上 角 出 现 了 一 个 “如 果 符 合 此 条 件 则 显示 ”的 灰色 卷 标 ， 这 表 
示 已 经 完成 设置 ， 如 图 5-51 所 示 。 
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图 5-51 “记录 集 不 为 空 ” 则 显示 
14) 输入 “对 不 起 ， 此 新 闻 分 类 中 没有 任何 新 闻 ” 说 明文 字 ， 同 时 选取 记录 集 没 有 数 




































































图 5-52 ”选择 没有 数据 时 显示 的 区 域 

15) 单 击 “ 应 用 程序 ”面板 中 的 “服务 器 行为 ”标签 上 的 由 按钮 ， 在 弹出 的 下 拉 菜 
中 选择 “显示 区 域 / 如 果 记 录 集 为 空 则 显示 区 域 ” 选 项 ,在 “记录 集 ” 中 选择 Recordsetl 再 
单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 显示 的 区 域 左 上 角 出 现 了 一 个 “如 
果 符 合 此 条 件 则 显示 ”的 灰色 卷 标 ， 这 表示 已 经 完成 设置 ， 效 果 如 图 5$-53 所 示 。 
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图 5-53 “记录 和 集 为 空 ” 则 显示 










QL*Dreamweaver 动态 网 站 开发 从 入 门 到 精通 





到 这 里 ， 新 闻 分 类 页 面 type. php 的 设计 与 制作 就 已 经 完成 。 


CERES 新 闻 内 容 页 面 设计 


新 闻 内 容 页 面 newscontent. php 用 于 显示 每 一 条 新 闻 的 详细 内 容 ， 这 个 页 面 设计 的 重点 
在 于 如 何 接收 主页 面 index. php 和 type. php 所 传递 过 来 的 参数 ， 并 根据 这 个 参数 显示 数据 库 
中 相应 的 数据 。 新 闻 内 容 页 面 的 页 面 设计 效果 如 图 5-54 所 示 。 
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PHP 新 闻 系 统 


是 新 新 闻 同学 录 人 简介 


新 闻 标 题 : 网 站 开通 了 加 入 时 间 : 2011-07-10 
新 闻 内 容 : 网 站 开通 了 ， 欢 迎 访问 
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Kd 5-54 新 闻 内 容 页 面 设 计 效 果 


详细 操作 步 又 如 下 。 

1) 执行 菜单 “文件 ”一 “新 建 ” 命 令 ， 创 建新 页 面 ， 执 行 菜单 “文件 ”一 “保存 ” 
命令 ， 在 站 点 中 news 文件 夹 中 将 该 文档 保存 为 newscontent. php. 

2) 页 面 设计 和 前 面 的 页 面 设计 差不多 ， 效 果 如 图 5-55 所 示 。 


函 CAxampp\htdocs\news\newscontent.php* -0x 
VAS news. php 
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K 5-55 新 闻 内 容 页 面 设计 
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3) 单 击 “ 绑 定 ” 面 板 中 的 “增加 ”上 的 四 按钮 ， 在 弹出 的 菜单 中 选择 “记录 集 (E 
询 ) ”命令 ， 在 打开 的 “记录 集 ” 对 话 框 中 进行 如 下 设置 。 
e 在 “名 称 ” 文 本 框 中 输入 Recordsetl 作为 该 记录 集 的 名 称 。 
e 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数 据 源 连 接 对 象 news。 C» 
e 从 “表格 ”下 拉 列 表 杠 中， 选择 使 用 的 数据 库 表 对 象 为 news。 
e 在 “ 列 ” 栏 中 选择 “全 部 ” 单 选 按钮 。 
e 设置 “筛选 ”的 条 件 为 : news_id = URL 78. news id, 
再 单 击 “ 确 定 ” 按 钮 完成 设 定 ， 如 图 5-56 所 示 。 


za EO 










































































K| 5-56 设置 “记录 集 ” 对 话 框 


4) 绑 定 记录 集 后 ， 将 记录 集 的 字段 搬 人 至 newscontent. php 页 面 中 的 适当 人 位置， 这样 就 
完成 了 新 闻 内 容 页 面 newscontent. php 的 设置 ， 如 图 5-57 所 示 。 



































I] CAxampp\htdocs\news\newscontent.php -0x 
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Kd 5-57 将 相应 字段 插入 至 新 闻 内 容 页 面 











EXE 后 台 管 理 页 面 设计 


新 闻 发 布 系统 后 台 管 理 对 于 网 站 很 重要 ， 管 理 员 可 以 通过 这 个 后 台 增 加 、 修 改 或 删除 新 
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闻 内 容 和 新 闻 的 类 型 ， 使 网 站 能 随时 保持 最 新 、 最 实时 的 信息 。 登 录 系 统管 理 入 口 页 面 的 设 
计 效 果 如 图 5-58 所 示 。 





TÈ cxampp\htdocs\news\admin\admin_login.php* = 口 X 


新 闻 后 台 管 理 中心 
用 FP | | 





g T, 








[X2 body> form formi WES 





图 5-58 系统 管理 入 口 页 面 


Soo 管理 入 口 页 面 


后 台 管 理 主页 面 必 须 受到 权限 管理 ， 可 以 利用 登录 账号 与 密码 判别 是 否 为 有 效用 户 来 实 








现 权限 的 设置 管理 。 

详细 操作 步骤 如 下 。 

1) 执行 菜单 “文件 ” “新 建 ” 命 令 ， 创 建 NIE EE 
新 页 面 , 输入 网 页 标题 “管理 员 登 录 " ， 执 行 菜单 summ m (E 
"b" “保存 ”命令 ， 在 站 点 news 文件 夹 中 的 exhi M 


admin 文件 夹 中 将 该 文档 保存 为 admin, login. php。 sama E 

2) 执行 菜单 “插入 ”一 “表单 ”一 “表单 ” ^ Em 
命令 ， 捅 入 一 个 表单 。 

3) 将 光标 放置 在 该 表单 中 ， 执 行 菜单 “插入 ” 
一 “表格 ”命令 , 打开 “表格 ”对 话 框 ,在 “ 行 
数 ” 文 本 框 中 ,输入 需要 插入 表格 的 行 数 4。 在 
“ 列 数 ”文本 框 中 ， 输 入 需要 插入 表格 的 列 数 2。 在 
“表格 宽度 ”文本 框 中 ， 输 入 400 像素 ， 其 他 参数 保 
持 默 认 值 ， 如 图 5-59 所 示 。 E AOE 

4) 单 击 “ 确 定 ”按钮 ， 在 该 表单 中 插入 了 一 个 4 行 2 列 的 表格 ， 选 择 表格 ， 在 “ 属 
性 ”面板 中 , 设置 “对 齐 方式 ”为 “居中 对 齐 ”。 拖 动 鼠 标 选择 第 1 行 表 格 所 有 单元 格 ， 在 
“属性 ”面板 中 单 击 加 按钮， 将 第 1 行 表格 合并 。 用 同样 的 方法 把 第 4 行 合并 。 

5) 在 该 表单 中 的 第 1 行 中 输入 文字 “新 闻 后 台 管理 中 心 "， 在 表格 的 第 2 行 第 1 个 单 
元 格 中 输入 文字 说 明 “ 账 号 :”， 在 第 2 行 表格 的 第 2 个 单元 格 中 单 击 “ 文 本 域 ” 按 钮 品 ， 
插入 单行 文本 域 表 单 对 象 ， 定 义 文本 域名 为 username。“ 文 本 域 ”属性 设置 如 图 5-60 所 示 。 
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加 文本 域 FAREM 类 型 〇 单行 6) OTM — Osa 类 (C) 无 
username 最 多 字符 数 初始 值 t) v 
OSA o) 
[1Ri à) 














5-60 username 文本 域 的 属性 设置 
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6) 在 第 3 列表 格 的 第 1 个 单元 格 中 ， 输 入 文字 说 明 “ 密 码 :;”， 在 第 3 列表 格 的 第 2 个 
单元 格 中 单 击 “ 文 本 域 ”按钮 回 ， 插 入 单行 文本 域 表 单 对 象 ， 定 义 文 本 域名 为 password, 






























































“文本 域 ”属性 设置 如 图 5-61 所 示 。 
e e 
fau] 文本 域 字符 宽度 0) 类 型 〇 单行 6) Osam OEBE) 类 人) 无 Y 
password 最 多 字符 数 初始 值 a) 多 
OSAD 
ORR R 




















图 5-61 password“ 文 本 域 ” 的 设置 

7) 单 击 选 择 第 4 行 单元 格 ， 执 行 两 次 菜单 “插入 ”一 “表单 ”一 “按钮 ”命令 ， 搬 

入 两 个 按钮 ， 并 分 别 在 “属性 ”面板 中 进行 属性 变更 ， 一 个 为 登录 时 用 的 “提交 表单 ” 选 
项 ， 另 一 个 为 “ 重 设 表单 ”选项 ， 其 属性 设置 及 效果 如 图 5-62a、b c 所 示 。 
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m 按钮 名 称 值 ) ex 动作 人 提交 表单 6) OFM 类 CC) 无 si 
Suit — |] OBERE m 
a) 
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[a 按钮 名 称 100 [EZ |] ”动作 〇 提交 表单 6) OX 类 (CC) | 无 * 
Subnit2 加重 设 表单 M) 


























HA AEE HO 
I < 


za [— — —— —] 
caa 


c) 
图 5-62 设置 按钮 名 称 的 属性 及 效果 
8) 单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 需 行 为 ”面板 上 的 四 按钮 ， 在 弹出 的 菜单 


中 选择 “用 户 身份 验证 /登录 用 户 ” 命 令 ， 打 开 “ 登 录用 户 ” 对 话 杠 ,设置 为 如 果 不 成 功 将 
返回 主页 面 index. php， 如 果 成 功 将 登录 后 台 管理 主页 面 admin. php， 如 图 5-63 所 示 。 












































ES) 
从 表单 获取 输 和 :[tum -| 
RPE [mm 0 or) [m4 
BR em Lm) 
使 用 和 连接 验证 : [news -| 
表格 ein 7j 
用 户 名 列 [sernene n 
如 果 登 录 成 功 ， 转 到 : admin. php Fm 
7] 转 到 前 一 个 URLG0 果 它 存在 
如 果 登 录 失 败 , 转 到 : /index.php Gi 





基于 以 下 项 限制 访 问 . € 用 户 名 和 密码 
O 用 户 名 、 密码 和 访问 名 别 
FEBA: 


CS 


K 5-63 设置 “登录 用 户 ” oim 




















TI 








动态 网 站 开发 从 入 门 到 精通 


9) 执行 菜单 “窗口 ”一 “行为 ”命令 ， 打 开 “ 行 为 ”面板 。 单 击 “ 行 为 ”面板 中 的 
四 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 检 查 表 单 ” 命 令 。 打 开 “ 检 查 表单 ”对 话 框 ， 设 置 user- 
name 和 password 文本 域 的 “ 值 ”都 为 “必需 的 ”, “可 接受 ”为 “任何 东西 ” ， 如 图 5-64 


所 示 。 














i ES "username" (R) 


























可 接受 : © 任何 东西 O 数字 
O 电子 邮件 地 址 ”加 数字 从 到 

















p. = 


图 5-64 “检查 表单 ”对 话 框 


单 击 “确定 ”按钮 ， 回 到 编辑 页 面 ， 完 成 后 台 管 理 入 口 页 面 admin_login. php 的 设计 与 
制作 。 


coru 管 理 主页 面 


后 台 管 理 主页 面 是 管理 员 在 登录 页 面 验证 成 功 后 所 登录 的 页 面 ， 这 个 页 面 可 以 实现 新 
兽 、 修 改 或 删除 新 闻 内 容 和 新 闻 分 类 的 内 容 ， 使 网 站 能 随时 保持 最 新 、 最 实时 的 信息 。 页 面 
结构 如 图 5-65 所 示 。 























E 360 安 全 浏览 器 7.1 «mew 一 口 X | 
|e C| Q| Ú Y http//127.00.1/news/admin/admin.php gv 
>| @ | Esm x |+ 





(Hems 


PHP 新 闻 系 统 
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最 新 新 闻 


新 闻 后 台 管 理 中 心 : 标题 : 网 站 开通 了 [修改 ] MBR] 
MAN 标题 : 这 是 测试 的 [修改 ] BRI 
添加 新 闻 


添加 新 闻 分 类 
管理 员 你 好 ! 。 ”请 你 管理 新 闻 分 类 ! 
类 (E: 


里 
Wb] 。 [修改 ] NR] 
Ep [修改 ] MR] 



































DS 


K 5-65 后 台 管 理 主页 面 效 果 











详细 操作 步骤 如 下 。 
1) 打开 admin. php 页 面 ，( 此 页 面 设 计 比 较 简单 ， 页 面 设计 在 此 不 做 说 明 ) , Rad; "2p 








新 闻 发 布 系统 














定 ” 面 板 上 的 四 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 记 录 集 (EW) MA, Æ WRR” X 
话 框 中 进行 如 下 设置 。 

e 在 “名 称 ” 文 本 框 中 输入 Re 作为 该 记录 集 的 名 称 。 

e 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数 据 源 连接 对 象 news, 

e 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 news。 

e 在 “ 列 ” 栏 中 选择 “全 部 ” 单 选 按钮 。 

e “排序 ”设置 为 news_id 降序 方式 。 

完成 的 设置 情况 如 图 5-66 所 示 。 


































































































KI 5-66 设置 “记录 集 ” 对 话 框 


2) 绑 定 记录 集 后 ， 将 Re 记录 集中 的 news, title 字段 插入 至 admin. php 网 页 中 的 适当 位 
置 ， 如 图 5-67 所 示 。 

















TE C: \Apachethtdocs\news\admin\admin. phpk -AX 
PIRED news. php 
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图 5-67 记录 和 集 的 字段 插入 至 admin. php 网 页 中 


3) 由 于 要 加 入 “重复 区 域 ”命令 ， 所 以 首先 选择 需要 重复 的 表格 ， 如 图 5-68 所 示 。 


e 











PHP*-MySQL-4* Dreamweaver 动态 网 站 开发 从 入 门 到 精通 








图 5-68 选择 重复 的 表格 


4) 单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 器 行为 ”面板 上 的 轿 按 钮 ， 在 弹出 的 菜单 
中 ， 选 择 “ 重 复 区 域 ”命令 ,打开 “重复 区 域 ”对 话 杠 ， 设 定 一 页 显示 的 数据 为 10 条 记 
录 ， 如 图 5-69 所 示 。 





























图 5-69 选择 记录 集 显示 的 记录 数 
5) 单 击 “确定 ”按钮 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 重复 的 区 域 左 上 角 出 现 了 一 


个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设 定 。 

6) 在 “插入 ” 栏 的 “数据 ”类 型 中 ， 单 击 | 区 | 工具 按钮 打开 “记录 集 导 航 条 ”对 话 框 ， 
选取 Re 记录 集 的 显示 方式 为 “文本 ”， 然 后 单 击 “ 确 定 ”按钮 回 到 编辑 页 面 ， 会 发 现 页 面 
出 现 该 记录 集 的 导航 条 ， 如 图 5-70 所 示 。 
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图 $-70 添加 “记录 集 导航 条 ” 


7) admin. php 是 提供 管理 员 链 接 至 新 闻 编 辑 的 页 面 ， 然 后 进行 新 增 、 修 改 与 删除 等 操 
作 。 设 置 了 4 个 链接 ， 各 链接 的 设置 如 表 5-6 所 示 。 


表 5-6 admin. php 页 面 的 链接 设置 














名 WW 链接 页 面 
标题 字段 | re. news title] newscontent. php 








新 闻 发 布 系统 














(5) 
AW 链接 页 面 
添加 新 闻 news, add. php 
修改 news, upd. php 
删除 news, del. php 








重点 说 明 : 其 中 “标题 字段 [re news ütle]", “修改 ”及 “删除 ”的 链接 必须 要 传递 
参数 给 转 到 的 页 面 ， 这 样 转 到 的 页 面 才能 够 根据 参数 值 而 从 数据 库 将 某 一 笔 数 据 筛 选 出 来 再 


进行 编辑 。 
8) 首先 选取 “添加 新 闻 ”， 在 “属性 ”面板 中 将 它 链 接 到 admin 文件 夹 中 的 news. add. 
php 页 面 。 


9) 选取 右边 栏 中 的 “修改 ”文字 ,在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 
“浏览 文件 ”图 标 ， 在 弹出 的 “选择 文件 ”对 话 框 中 选择 用 来 显示 详细 记录 信息 的 页 面 news 
_upd. php， 设 置 如 图 5-71 所 示 。 








































































名 称 修改 日 其 aem 大 小 

Ji notes 2014/12/8 10402 — 文件 去 

目 admin.php. 2014/12/816:33 PHP 文件 11KB 

国 admin login.php. 2014/12/816:28 PHP 文件 5 KB 

国 news_add.php 2011/7/8 16:26 PHP 文 件 7KB 
J news_del.php 2011/7/10 12:00 PHP 文件 6 KB | 

=| | news upd.php 2011/7/10 11:46 — PHP 文件 6 KB | 

] type add.php 2011/7/8 16:05 PHP 文件 5 KB 
j type_del.php 2011/7/10 12:18 PHP 文件 4KB 
3 type_upd.php 2011/7/10 12:10 PHP 文件 4KB 

F: | 文档 ~ 

文件 名 (N): news upd.php ~ ”| 所 有 文件 (n) X 

















Kl 5-71 


选择 链接 文件 


10) 单 击 “ 确 定 ” 按 钮 ， 设 置 超级 链接 要 附带 的 URL 参数 的 名 称 与 值 news_upd. php? 
news, id =< ? php echo $row_Re[ news id ]; ? > ， 如 图 5-72 所 示 。 
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11) 选取 “删除 ”文字 并 重复 上 面 的 操作 ， 要 转 到 的 页 面 改 为 news, del. php, JFE 
新 闻 标 题 的 ID 参数 news, del. php? news, id =<? php echo $row, Re[ news id ]; ? > ll 
图 5-73 所 示 。 
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图 5-72 
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文件 名 (N): news_delphp 


相对 于 : | 文档 - 





HR Y 新 建文 件 夫 
圈 最 5 访问 的 位 置 人 名 称 à 修改 日 其 aem 大 小 

E Ji notes 2014/12/8 10:42 文件 夫 

司库 admin.php 2014/12/816:33 PHP 文件 11KB 
Bus Ej admin login.php. 2014/12/8 16:28 PHP 文件 5 KB 
a] 图 片 国 news add.php 2011/7/8 16:26 PHP 文件 7 KB 
F3 xc | Li news del.php 2011/7/10 12:00 — PHP 文件 6 KB 
&) RETE L E news upd.php 2011/7/10 11:46 PHP 文件 6 KB 
由 音乐 | Ei type add.php 2011/7/8 16:05 PHP 文件 5 KB 

El type. del.php 2011/7/10 1248 PHP 文件 4KB 
"EO type upd.php 2011/7/10 1210 — PHP 文件 4KB 








Kj 5-73 设置 传递 至 news_del. php 











© e 


站 开发 从 入 门 到 精通 


12) 选取 标题 字段 | Re_news_title| 并 重复 上 面 的 操作 ， 要 前 往 页 面 改 为 newscon- 
tent. php 并 传递 新 闻 参 数 .. / newscontent. php? news, id =<? php echo $row_Rel news id ]; ?», 
如 图 5-74 所 示 。 





















































Kd 5-74 


设置 传递 至 





È newscontent. php 


TSE 名 称 s 修改 日 期 am 大 小 
» Ji _mmserverscripts 2014/12/81613 — 文件 夫 
GE J notes 2014/12/8 10:442 — 文件 夫 

Hus J admin 2014/12/816:33 ”文件 夫 

E) 图 片 Ji Connections 2014/12/8 10:442 — 文件 夫 

文档 Ji data 2014/12/8 10:42 — 文件 夫 

i) RETE =| ji images 2014/12/813:50 ”文件 夫 | 

由 音乐 E index.php 2011/7/8 18:20 PHP 文件 9 KB 

[L] newscontentphp 2011/7/9 8:00 PHP 文件 4KB| 

muB" Ei type.php 2011/7/9 7:53 PHP 文件 8KB 

& Acer (C) 

ca 本 地 磁盘 (Dj 

c ARR E T 

相对 于 : | 文档 - 
文件 名 (N): newscontent.php 








13) 单 击 “ 确 定 ” 按 钮 ， 完 成 转 到 详细 页 面 的 设置 。 至 此 , 已 经 完成 了 新 闻 内 容 的 编 
辑 ， 现 在 来 设置 一 下 新 闻 分 类 。 单 击 “ 绑 定 ” 面 板 上 的 [ 凤 按 钮 ， 在 弹出 的 菜单 中 ， 选 择 
“记录 和 集 (AEW) MO, 在 “记录 和 集 ”对 话 框 中 进行 如 下 设置 。 

e 在 “名 称 ” 文 本 框 中 输入 Rel 作为 该 记录 集 的 名 称 。 

e 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数 据 源 连接 对 象 news。 

e 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 newstype。 

e 在 “ 列 ” 栏 中 选择 “全 部 ” 单 选 按钮 。 

完成 的 设置 情况 如 图 5-75 所 示 。 
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图 5-75 ”设置 “记录 集 ” 对 话 框 
14) 绑 定 记录 集 后 ， 请 将 Rel 记录 集中 的 type name 字段 搬入 至 admin. php 网 页 中 的 适 
当 位 置 ， 如 图 5-76 所 示 。 


* C: \Apache\htdocs\news\admintadmin. php =- 0x 


De news. php Y 
; D: a 
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Kd 5-76 插入 相应 字段 至 admin. php 网 页 中 
15) 加 入 “服务 器 行为 ”中 “重复 区 域 ”命令 ， 选 择 需 要 重复 的 表格 ， 如 图 5-77 
所 示 。 
16) 单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 器 行为 ”面板 上 的 轩 按 钮 ， 在 弹出 的 菜单 


中 ， 选 择 “ 重 复 区 域 ” 命 令 ， 打 开 “ 重 复 区 域 ” 对 话 框 ， 设 定 一 页 显示 的 数据 为 “所 有 记 
录 ”， 如 图 5-78 所 示 。 

















: fRel.type namel [修改 ] [删除 ] : 


图 5-77 ”选择 要 重复 的 表格 图 5-78 设置 “重复 区 域 ”对 话 相 
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17) 单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 重复 的 区 域 左 上 角 出 现 了 
一 个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设置 。 

18) 首先 选取 左边 栏 中 的 “修改 ”文字 ， 选 择 admin 文件 夹 中 的 type_upd. php 链接 并 
传递 type. id 参数 type_upd. php?type id =<? php echo $row Relf type id ]; ? >， 如 图 5-79 
所 示 。 




















修改 日 期 


Ji notes 2014/12/8 10:42 
9 admin.php 2014/12/8 16:33 
四 admin login.php 2014/12/8 16:28 
news add.php 2011/7/8 16:26 

L news del.php 2011/7/10 12:00 
E) news upd.php 2011/7/10 11:46 
E) type add.php 2011/7/8 16:05 

E) type del.php 2011/7/10 1218 
[Li type. upd.php. 2011/7/10 12:10 
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"^ i 


文件 名 (N): type upd.php 











图 5-79 设置 传递 至 type_upd. php 


19) 选取 “删除 ”文字 并 重复 上 面 的 操作 ， 要 前 往 的 细节 页 面 改 为 type_del php 并 传 
递 type_id 参数 type, del. php? type. id =<? php echo. $row, Rel[ type. id ]; ? >， 如 图 5-80 
所 示 。 








| 组织 ” 新 建文 件 夫 
di 最 访问 的 位 置 “ 名 称 修改 日 期 aem 


Ji .notes 2014/12/8 10:42 — 文件 夫 
^| admin.php 2014/12/816:33 — PHP 文件 
Bus ^ admin login.php 2014/12/816:28 PHP 文件 
i| 图 片 Ej news add.php 2011/7/8 16:26 PHP 文件 
B xus news delphp 2011/7/10 12:00 PHP 文件 
图 REFS *| [E news_upd.php 2011/7/10 11:46 — PHP 文件 
AER type_add.php 2011/7/8 16:05 ”PHP 文件 
[L type. del.php 2011/7/10 1248 — PHP 文件 
msn L1 type upd.php 2011/7/10 12:10 — PHP 文件 

色 Acer (C) 

ca 本 地 磁盘 (Dj 

ca 本 jp 磁盘 E T 


相对 于 : | 文档 ~ 

































































文件 名 (N): type del.php 














图 5-80 设置 传递 至 type_del. php 


20) 再 选取 “添加 新 闻 分 类 ”， 在 “属性 ”面板 中 将 它 链接 到 admin 文件 夹 中 的 type. 
add. php 页 面 。 























52 ELAES 


21) 后 台 管 理 页 面 是 管理 员 在 后 台 管理 入 口 页 面 admin_login. php 输入 正确 的 账号 和 密 
码 才 可 以 进入 的 一 个 页 面 ， 所 以 必须 设置 限制 对 本 页 的 访问 功能 。 单 击 “ 应 用 程序 ”面板 
群 组 中 “服务 器 行为 ”面板 中 的 外 按钮 ， 在 弹出 的 菜单 中 ,选择 “ 用 户 身 份 验证 /限制 对 页 
的 访问 ”选项 ， 选 择 “ 限 制 对 页 的 访问 ”命令 ， 如 图 5-81 所 示 。 
































Dw 文件 80 查看 (V) AD 修改 (M) ERO SAO 站 点 (S) SOW 帮助 (H) BE. EH ol- alx | 
| f i8 [设计 ] xum O. 标题: 管理 页 面 O | HW 
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图 5-81 选择 “限制 对 页 的 访问 ”命令 





22) 在 打开 的 “限制 对 页 的 访问 ”对 话 框 中 的 “基于 以 下 内 容 进行 限制 ”选择 “用 户 
名 和 密码 " ， 如 果 访 问 被 拒绝 ， 则 转 到 首页 index. php, WME 5-82 所 示 。 


O RAR 密码 和 访问 级 别 
选取 级 别 : 



































图 5-82 设置 “限制 对 页 的 访问 ”对 话 框 


单 击 “确定 ”按钮 ， 就 完成 了 后 台 管理 主页 面 admin. php 的 制作 。 


SELL 新 增 新 闻 页 面 


新 增 新 闻 页 面 news. add. php 设计 的 页 面 效果 如 图 5-83 所 示 ， 主 要 是 实现 插入 新 闻 的 功 
能 。 详 细 操 作 步 又 如 下 。 









动态 网 站 开发 从 入 门 到 精通 




















| pana: 
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K5-83 新 增 新 闻 页 面 设计 





1) 创建 news_add. php 页 面 ， 并 单 击 “ 绑 定 ”面板 上 的 时 按钮， 在 弹出 的 菜单 中 ， 
选择 “记录 集 (EDU p, 在 打开 的 “记录 集 ” 对 话 框 中 进行 如 图 5-84 所 示 的 
设置 。 

2) 绑 定 记录 集 后 ， 单 击 “ 新 闻 分 类 ”的 列表 菜单 ， 在 “新 闻 分 类 ”的 列表 菜单 属性 
mit, AEE as. 按钮， 在 打开 的 “动态 列表 /菜单 ”对 话 框 中 进行 相关 设置 ， 如 
图 5-85 所 示 。 
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菜单 : | "news_type" 在 RẸ “formi” ~ 
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名 称 : Recordset1 x 静态 选项 ala 5 

ea REÓÓ | a 





表格 : | newstype - | 











来 自 记录 和 集 的 选项 。 [Recordsetlsss 





























" T s f[mei 000 0r] 
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Bs [x 到 [升序 * 选取 值 等 于 <?php $row Recordsetl['type £l 
































图 5-84 设置 “记录 集 ” 对 话 框 图 5-85 设置 “动态 列表 / 荣 单 ” 对 话 村 

3) 本 章 中 的 一 个 技术 重点 就 是 要 使 用 PHP 实现 自动 获取 系统 的 默认 时 间 ， 当 插入 新 闻 

时 能 自动 生成 当时 的 时 间 。 方法 是 绑 定 一 个 隐藏 字段 并 命名 为 news_date， 切 换 到 代码 行将 
值 设置 如 下 : 








IMI 





« input name = " news_date" type =" hidden" id =" news_date" value =" <?php 
date default timezone set( Asia/Shanghai ) ; 
echo date(" Y -m - d") ; 


新 闻 发 布 系统 





?了 >" > 


// 设 置 时 间 格式 和 时 间 区 域 


4) 单 击 “确定 ”按钮 ， 在 news add. php 编辑 页 面 ， 再 次 单 击 “应 用 程序 ”面板 群 组 
中 “服务 器 行为 ”面板 上 的 出 按钮， 在 弹出 的 菜单 中 ， 选 择 “ 搬 入 记录 ”命令 ， 如 图 5-86 
所 示 。 











































































































Dn ey E E ol x | 
news addphp* x p ad add.php 
news. php m 
Í 设计 Q9. um x Mt 
d 请 添加 新 闻 : 
新 闻 标题 : 
新 闻 分 类 : * 作者 : 
m 
新 闻 内 容 : 
- * 回 
ATEM Dm) (S8) «opm m 
RAJ body — form formi Hg EE 783 x 376v 
EE 
(<>|) EEN [无 = z) 类 | 无 - BI Eie güD|[ | 
Bis css ID) formi . BHO "Og BO - 
Caneta] SARE. 























K 5-86 ”选择 “插入 记录 ”选项 
5) 在 “插入 记录 ”的 设 定 对 话 框 中 ,输入 如 图 5-87 所 示 内 容 。 





















































lire 
I —— 


插入 后 ， 转 到 : adnin. php | GR. 


























E —— = —— / 


图 5-87 设置 “搬入 记录 ” 对 话 村 


6) 执行 菜单 “窗口 ”一 “行为 ”命令 , 打开“ 行为” 面板， 单 击 “ 行 为 ”面板 上 的 
[按钮 ， 在 打开 的 菜单 中 ,选择 “检查 表单 ”命令 。 打 开 “ 检 查 表单 ”对 话 杠 ,设置 值 都 
为 “必需 的 ”,“ 可 接受 ”为 “任何 东西 ” ， 如 图 5-88 所 示 。 

单 击 “ 确 定 ”按钮 回 到 编辑 页 面 ， 就 完成 news_add. php 页 面 的 设计 了 。 
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动态 网 站 开发 从 入 门 到 精通 






































可 接受 : © 任何 东西 O 数字 
O 电子 邮件 地 址 O 数字 从 












Hi 





图 5-88 设置 “检查 表单 ”对 话 框 


S 修改 新 闻 页 面 


修改 新 闻 页 面 news_upd. php 的 主要 功能 是 将 数据 表 中 的 数据 送 到 页 面 的 表单 中 进行 修 
改 ， 修 改 数据 后 再 将 数据 更 新 到 数据 表 中 ， 页 面 设计 如 图 5-89 所 示 。 





TÈ cxampp\htdocs\news\admin\news_upd.php* 20x 

















并: 
| Bii: 


; grana: 
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1 
body. form #forn! table Myo td span .STYLE| [Ibe] EE E ssai . 








图 5-89 修改 新 闻 页 面 设 计 


详细 操作 步骤 如 下 。 

1) 打开 news upd. php 页 面 ， 并 单 击 “ 绑 定 ” 面 板 上 的 固 按 钮 ， 在 弹出 的 菜单 中 ， 
选择 “记录 集 (查询 )” 选 项 ， 在 打开 的 “记录 集 ”对 话 框 中 ,输入 如 图 5-90 所 示 
内 容 。 

2) 用 同样 方法 再 绑 定 一 个 记录 集 Recordset2 ， 在 “记录 和 集 ” 的 设置 如 图 5-91 所 示 。 

3) 绑 定 记录 集 后 ， 将 记录 集 的 字段 搬 和 人 至 news  upd. php 网 页 中 的 适当 位 置 ， 如 
图 5-92 所 示 。 其 中 加 入 一 个 隐藏 字段 绑 定 news. id; 







v9 9 oo e : 
2000000699 .00009 
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fcm . — 
|| Ær: Recordset2 ] 
rpm. — — — pum.) mA) 
: mit 
表格 : newstype -] 
I URP NNUS (GER. ] 
i HM qun - WE 
news id type id 
news title type nana 
news type 
news content 
news date 
di — — T ma zJE s 
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= lH] T 5 7 





图 5-90 设置 “记录 集 Recordsetl" 对 话 框 图 5-91 设置 “记录 集 Recordset2” 对 话 框 





函 CAxampp\htdocs\news\admin\news_upd.php* -0x 
news. php 

1 管理 员 ， 你 好 ! BRERA! 

| 新闻 标 题 | (Recordsetl.nevs title] 回 

; 更 新 时 间 : | 

;新 闻 分 类 : 7 作者 {Recordset1 

: ÍRecordseti.news content] ^ 





A 





]» 








新 闻 内 容 : 






































5 i 86 (83) * 508 (551) 2 | 
| 650 | 
[3> body form ... table — tr td span .STILE| label B E EN e xa 


1 























图 5-92 插入 相应 字段 至 news_upd. php 网 页 中 


4) 在 “更 新 时 间 ” 一 栏 中 必须 取得 系统 的 最 新 时 间 ， 方 法 和 上 面 加 隐藏 字段 取得 时 间 


的 方法 一 样 ， 直 接 在 初始 值 字段 输入 取得 系统 时 间 的 代码 ， 如 图 5-93 所 示 。 
























































属性 
= 文本 域 字符 宽度 QUO) 30 类 型 OTO Osam Ossa e) 类 CC) 无 
news_date 最 多 字符 数 TURAÍB (I) | phpdate default timezone set( A) 47 
OSA a 
L]Ri& ao 


Kd 5-93 ”加 入 代码 取得 最 新 时 间 


<input name = " news date" type 2" text" id 2" news date" value =" < ? php 
date default timezone set( Asia/Shanghai ) ; 

echo date(" Y -m - d") ; 

7» 


5) 单 击 “ 新 闻 分 类 ”的 列表 菜单 ， 在 “新 闻 分 类 ”的 列表 菜单 属性 面板 中 ， 
区  sm&. 按钮， 在 打开 的 “动态 列表 /菜单 ”对 话 框 中 ,设置 如 图 5-94 所 示 内 容 。 
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ES WELT: 


ee 
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菜单 : [necs type" 在 XÉ "formi" x| 

















图 5-94” 绑 定 “动态 列表 /菜单 ” 





6) 完成 表单 的 布置 后 ， 要 在 news_upd. php 这 个 页 面 加 入 “服务 器 行为 ”中 “更 新 记 
录 ” 的 设 定 ， 在 news upd. php 的 页 面 上 ， 单 击 “ 应 用 程序 ”面板 群 组 中 “服务 器 行为 ” 面 
板 上 的 四 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 更 新 记录 ”命令 ， 如 图 5$-95 所 示 。 


管理 员 ， 你 好 ! 请 你 修改 新 闻 ! 


[Recordsetl.news title] a 
匣 新 时 间 : X?phpdate default timezone se 
扬 闻 分 类 : | [x] 作者 | {Recordset1 




















[Recordseti.news content] 




















K 5-95 加 入 “更 新 记录 ”命令 








7) 在 打开 的 “更 新 记录 ”对 话 框 中 ,设置 如 图 5-96 所 示 内 容 。 其 中 news id 设置 为 
主键 。 
单 击 “ 确 定 ” 按 钮 ， 即 完成 修改 新 闻 页 面 的 设计 。 














ent! pasi XE 
news_date’ 从 “了 DORN news zaf 
news author! 从 " FORI. ness. author Hi x 本 











i 
提交 为 — 


在 更 新 后 ， 转 到 : admin. php 

















K 5-96 设置 “更 新 记录 ” X 


S5 删除 新 闻 页 面 


删除 新 闻 页 面 news, del. php 和 修改 新 闻 页 面 差 不 多 ， 如 图 5-97 所 示 。 其 方法 是 将 表单 
中 的 数据 从 站 点 的 数据 表 中 删除 。 
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Mücewensciqeemsinimven deg UII 
news. php 
; 管理 员 ， 你 好 ， 你 要 量 除 此 新 闻 吗 ? 
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图 5-97 删除 新 闻 页 面 的 设计 


详细 操作 步骤 如 下 。 

1) 打开 news del php 页 面 ， 单 击 “ 绑 定 ”面板 上 的 外 按钮 ， 接 着 在 弹出 的 菜单 中 ， 
选择 “记录 集 (EW) ME, 在 打开 的 “记录 集 ” 对 话 框 中 ,输入 如 图 5-98 所 示 
内 容 。 

2) 用 同样 方法 再 绑 定 一 个 记录 集 ， 输 入 设 定 值 ， 如 图 5-99 所 示 。 

3) 绑 定 记录 集 后 ， 将 记录 集 的 字段 插 和 人 至 news. del. php 网 页 中 的 适当 位 置 ， 其 中 绑 定 
隐藏 字段 为 news_id， 如 图 5-100 所 示 。 









OO t 
© © è o 
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名 称 : Recordset2 





连接 : 
表格 : 
列 :@ 全 部 O 选 定 的 : 





连接 : 


news id 

news title 
news type 
news content 
news date 


A: [news id r=: > 
"URL 参数 m| news_id 
































Perr: a —  -] 























5-98 “记录 集 Recordset1 ”对话 框 








男 cvamppWtdocsmewsvadminmews del php* 


-0x 
edu» 了 | 






;管理 员 ， 你 好 ， 你 要 是 除 此 新 闻 吗 ? 





' ÍRecordsetl.news title] 回 i 
.Mia 类 — [ [el 


ÍRecordsetl.news content] 


E 




















D [textarea> Hg HH 613 x 324v sil 


KI 5-100 字段 的 搬入 


4) 绑 定 记录 集 后 ， 单 击 “新 闻 分 类 ”的 菜单 ， 在 “新 闻 分 类 ”的 菜单 属性 面板 中 ， 单 
击 区 _ 药 .按钮 ， 在 打开 的 “动态 列表 /菜单 ”对 话 框 中 设置 如 图 5-101 所 示 内 容 。 





sé | "select" 在 表单 “forml” 


BDH: gi 











| 来 自 记录 集 的 选 顺 -|Recordset2ssss===23| 
| 人 
m: 


选取 值 等 于 ，《?php $row Recordset2[ type £A 

















图 5-101” 绑 定 “ 动 态 列 表 / 菜 单 ” 
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5) 完成 表单 的 布置 后 ， 要 在 news del php 这 个 页 面 加 入 “服务 器 行为 ”面板 中 “删除 
记录 ”的 设置 。 单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 器 行为 ”面板 上 的 图 按 钮 ， 在 弹出 
的 菜单 中 ， 选 择 “ 删 除 记 录 ” 命 令 ， 在 打开 的 “删除 记录 ”对 话 框 中 ， 输 入 设 定 值 ， 如 


图 5-102 所 示 。 n 




































































| 首先 检查 是 否 已 定义 变量 :主键 值 = 
连接 : (x) 
L| 3E [news x| 
表格 : [news 四 帮助 
FSI: [pesid] dg 
主键 值 : URL 参数 winews_id 
WRA. $F]: admin. php (3c) | 


K 5-102 设置 “删除 记录 ” 对 话 框 
单 击 “确定 ”按钮 ， 完 成 删除 新 闻 页 面 的 设计 。 


ceras 新 增 新 闻 分 类 


新 增 新 闻 分 类 页 面 type_add. php 的 功能 是 将 页 面 的 表单 数据 新 增 到 newstype 数据 表 中 ， 
页 面 设计 如 图 5-103 所 示 。 





B Cvxampp\htdocs\news\admin\type_add.php* 


MASAE: 


H0) —^ 


























K 5-103 新 增 新 闻 分 类 页 面 设计 








详细 操作 步骤 如 下 。 
1) 单 击 “ 应 用 程序 ”面板 群 组 中 “服务 器 行为 ”面板 中 国 按钮 ， 在 弹出 的 菜单 中 ， 
选择 “插入 记录 ”命令 ， 在 打开 的 “插入 记录 ”对 话 杠 中， 输入 六 et. 如 图 5-104 所 示 。 






























































| 插入 后 ， 转 到 : admin. php . Dä 


























图 $-104 设置 “搬入 记录 ”对 话 框 
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2) 选择 表单 执行 菜单 “窗口 ”一 “行为 ”命令 ， 打 开 “ 行 为 ”面板 ， 单 击 “ 行 为 ” 
面板 中 的 由 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 检 查 表单 ”命令 。 打 开 “ 检 查 表单 ”对 话 框 ， 
设置 “ 值 ”为 “必需 的 ” ,“ 可 接受 ”为 “任何 东西 "， 如 图 5-105 所 示 。 




















- ERES 





















可 接受 : © 任何 东西 O 数字 
O 电子 邮件 地 址 © 数字 从 








图 5-105 设置 “检查 表单 ”对 话 框 
3) 单 击 “ 确 定 ” 按 钮 ， 完 成 type_add. php 页 面 设计 。 


ERE TERME. 修改 新 闻 分 类 


修改 新 闻 分 类 页 面 type_upd. php 的 功能 是 将 数据 表 的 数据 送 到 页 面 的 表单 中 进行 修改 ， 
修改 数据 后 再 更 新 至 数据 表 中 。 页 面 设计 如 图 5-106 所 示 。 


Tl cxampp\htdocs\news\admin\type_upd.php* -0x 


news. php T, 








类 名 称 : 

















— | x) E 











R> body> form formi DD E sori € 





Ki 5-106 修改 新 闻 分 类 页 面 设计 





详细 操作 步 又 如 下 。 

1) 打开 type_upd. php 页 面 ， 并 单 击 “ 应 用 程序 ”面板 群 组 中 “ 绑 定 ”面板 的 轿 按 钮 。 
接着 在 弹出 的 菜单 中 ， 选 择 “ 记 录 集 (查询 )” 命 令 ， 打 开 “ 记 录 集 ”对 话 框 ， 在 打开 的 
“记录 集 ” 对 话 框 中 ， 输 入 设 定 值 ， 如 图 5-107 所 示 内 容 。 


Ly 
























































图 5-107 设置 “记录 集 ” 对 话 框 











2) 绑 定 记录 集 后 ， 将 记录 集 的 字段 搬 和 人 至 type. upd. php 网 页 中 的 适当 位 置 ， 如 
图 5-108 所 示 。 其 中 绑 定 一 个 隐藏 字段 为 type_id。 





TÈ cxampp\htdocs\news\admin\type_upd.php* -0x 
news. php m 
请 个 改 新 闻 分 类 : 
分 类 名 称 : {Recordset1. type. name] 
: ma E : 
| 6 一 + 33. i 
g | = -— : 























body — form #forn! table yo de [inpsbo Hype id [NN W siv . 




















KI 5-108 ”字段 插入 至 type_upd. php 


3) 完成 表单 的 布置 后 ， 要 在 type_upd. php 这 个 页 面 加 入 “服务 器 行为 ”中 “更 新 记 
录 ” 的 设 定 ， 在 type_upd. php 的 页 面 上 ， 单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 器 行为 ” 
面板 的 外 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 更 新 记录 ”命令 。 在 打开 的 “更 新 记录 ” 对话 框 
中 ， 输 入 设 定 值 ， 如 图 5-109 所 示 。 

















更 新 表格 : 








: BTRERE 1: twpe id 作为 “整数 ”来 选 择 记录 
pe | name n i type name" 获取 值 "NA 




















18: | FORM. type id - 
提交 为 : | 整数 -A 


在 更 新 后 ， 转 到 : admin. php 





























图 5-109 设置 “更 新 记录 ”对 话 框 
单 击 “确定 ”按钮 ， 完 成 修改 新 闻 分 类 页 面 的 设计 。 


SY AN ER BI 2) 35 


删除 新 闻 分 类 页 面 type. del. php 功能 是 将 表单 中 的 数据 从 站 点 的 数据 表 newstype 中 删 
除 。 详 细 操作 步骤 如 下 。 

1) 打开 type_del. php 页 面 ， 该 页 面 和 更 新 的 页 面 是 一 样 的 。 单 击 “ 应 用 程序 ”面板 群 
组 中 “ 绑 定 ”面板 的 四 按钮 。 接 着 在 弹出 的 菜单 中 ， 选 择 “ 记 录 集 (查询 ) ”命令 ， 打 开 
“记录 集 ” 对 话 框 ， 在 打开 的 “记录 集 ” 对 话 框 中 ， 输 入 设 定 值 如 图 5-110 所 示 。 

2) 绑 定 记录 集 后 ， 将 记录 集 的 字段 插入 至 type, del. php 网 页 中 的 适当 位 置 ， 如 图 5$-111 
所 示 。 其 中 绑 定 一 个 隐藏 字段 为 type_id。 

















动态 网 站 开发 从 入 门 到 精通 





ZW. Recordset1 
连接 : | news 








表格 : newstype 








列 :@ esp O 选 定 的 : 
type_id 
type_name 






























































图 5-110 设置 “记录 集 ” 对 话 框 























Tl cxampp\htdocs\news\admin\type_del.php* -0x 
news. php m 
[分 类 | Fam 
d ÍRecordsetl.type name] |I 
| 
ERES | 61€ — 333- c ME 
| Wr 























图 5-111 字段 插入 至 type del. php 


3) 完成 表单 的 布置 后 ， 要 在 type_del. php 这 个 页 面 加 入 “服务 器 行为 ”中 “删除 记 
录 ” 的 设 定 。 在 type_del. php 的 页 面 上 ， 单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 器 行为 ” 
面板 的 固 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “删除 记录 ”选项 。 在 打开 的 “删除 记录 ” 对 话 杠 
中 ， 输 入 设 定 值 ， 如 图 5-112 所 示 。 
































Boc EE: [ERE | 
连接 : [pews . x] 取消 
表格 : |newstype — - 

二 d 
E 





删除 后 ， 转 到 : admin. php 














K 5-112 设置 “删除 记录 ” 对 话 框 


至 此 一 个 功能 完善 、 实 用 的 网 站 新 闻 发 布 系统 就 开发 完毕 ， 读 者 可 以 将 本 章 开发 新 闻 发 
布 系统 的 方法 应 用 到 实际 的 大 型 网 站 建设 中 。 


^v^ 


= ”留言 板 管理 系统 


留言 板 管理 系统 可 以 实现 网 站 与 访问 者 之 间 的 沟通 ， 收 集 用 户 意 见 和 信息 ， 也 是 网 站 建 
设 中 必 不 可 少 的 一 个 重要 系统 。 利 用 留言 板 ， 可 以 为 访问 人 员 提 供 发 言 的 机 会 ， 及 时 、 准 确 
地 发 表 自 己 的 观点 。 这 些 观点 被 保留 在 服务 器 上 的 数据 库 中 ， 而 且 可 以 被 任何 一个 访问 站 点 
的 人 所 看 到 。 本 章 将 利用 Dreamweaver 的 “插入 记录 ”和 “查询 ”记录 集 命令 ， 轻 松 实现 
PHP 留言 系统 的 留言 和 查询 留言 的 动态 管理 功能 ， 同 时 开始 初步 掌握 通过 手写 代码 来 实现 


部 分 简单 的 功能 。 





EL VAVEEZE ILU 


主要 掌握 以 下 知识 点 


留言 板 管理 系统 的 结构 搭建 
创建 数据 库 和 数据 库 表 


建立 数据 库 连 接 
is 留言 板 管理 系统 中 创建 各 种 页 面 及 页 面 之 间 传 递 信息 的 技巧 和 方法 


留言 板 管理 系统 常用 功能 的 设计 与 实现 
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系统 整体 设计 规划 











留言 板 管理 系统 在 功能 上 主要 表现 为 如 何 显示 留言 ， 如 何 对 留言 进行 回复 、 修 改 和 删 
除 ， 一 个 完整 的 留言 板 管理 系统 分 为 访问 者 留言 模块 和 管理 者 登录 模块 两 部 分 。 
本 章 要 制作 的 留言 板 管理 系统 的 网 页 及 网 页 结构 ， 如 图 6-1 所 示 。 









系统 


index.php 









访问 者 留言 









admin.php 
delbook.php Teply.php 


图 6-1 系统 结构 图 


admin login.php 





留言 板 管理 系统 共有 6 个 页 面 ， 各 页 面 的 功能 与 对 应 的 文件 名 称 如 表 6-1 所 示 。 


表 6-1 留言 板 管理 系统 网 页 表 



























































页 面 名 称 Xx 能 
index. php 留言 内 容 显示 页 面 ， 显 示 留 言 内 容 和 管理 者 回复 内 容 
book. php 留言 页 面 ， 提 供用 户 发 表 留 言 的 页 面 

admin | login. php 管理 者 登录 入口 页 面 ， 是 管理 者 登录 留言 板 管理 系统 的 和 人口 页 面 
admin. php 后 台 管理 主页 面 ， 是 管理 者 对 留言 的 内 容 进 行 管理 的 页 面 
reply. php 回复 留言 页 面 ， 管 理 者 对 留言 内 容 进 行 回复 的 页 面 











m 


delbook. php 虽 除 留言 页 面 ， 管 理 者 对 一 些 非法 或 不 文明 留言 进行 删除 的 页 面 


"oL 页 面 设计 规划 


完成 留言 板 管理 系统 的 整体 规划 后 ， 可 以 在 本 地 站 点 上 建立 站 点 文件 夹 gbook， 将 要 制 
作 的 留言 板 系 统 文件 夹 及 文件 如 图 6-2 所 示 。 













DO 09 6 0 0020 

e0o0o0e066e26e030230 

000002*..- 20000000 
@@@eeee。。。.. - «v0 6 


»906060606€6€29255-.- 





eeoec00 


«000060 












































-—9 

oO ”计算 机 ， » xampp » htdocs » gbook » 

i XM) dE) ”查看 (V) 工具 (帮助 (H) ——— 

fiv 包含 到 库 中 v 共享 " 刻录 ”新 建文 件 夫 
ji BJcAROOT ^ £f 修改 日 其 类 型 大 小 
d Gi 国  mmServerScripts 2015/1/16 15:05 文件 夫 
di dic D notes 2015/1/16 15:05 x4 
ji Dolby PCEE4 Jl Connections 2015//1615:05 ”文件 夫 
Ji inetpub Ji date 2015/1/16 15:06 — Xtétzk 
Ji log Ji images 2015/1/16 15:05 — 文件 夫 | 
B v E] admin.php 2015/1/16 15:05 — PHP 文件 9 
lli Pertogs E] admin login.php 2015/1/16 15:05 PHP 文件 5 
iji Program Files E book php 2015/1/16 15:05 — PHP 文件 10 
li Program Files (x86) = delbook.php 2015/1/16 15:06 PHP 文件 8 
F index.php 2015/1/16 15:06 PHP 文件 12 
QvodPl =$ 
i M ED Ej reply.php. 2015/1/16 15:06 PHP 文件 9 
à xampp — | 
d n to [LÁ ÀÓl€——M mn a 
) 11 个 对 象 











图 6-2 站 点 规划 文件 


网 页 美工 方面 ， 主 要 设计 了 首页 和 次 级 页 面 ， 采 用 的 是 标准 的 左右 布局 结构 。 留 言 页 面 
设计 效果 如 图 6-3 所 示 ， 主 要 是 基于 一 个 BtoC 电子 商务 平台 的 留言 系统 的 开发 。 


& 360 安 全 浏览 器 7.1 «me|w — n x | 
[€ CQ O fr Y http//127.00.1/9book/ Bv 


>| © | zsm x |+] RS 


^ 




















PHPusessa [Paesana QER) 






首页 1 新 闻 动 态 1 信息 知识 | 信息 产业 | HAAD | 在 线 留言 | 联系 我 们 
会 员 登 录 你 的 位 置 -在线 留 言 现在 时 间 是 : 2015-01-16 03:07:50 
| gS 


DERE | 。 如 果 你 有 什么 问题 村 要 咨询 的 活 ， 请 单 击 留言 给 我 留言 ， 我 们 会 第 一 时 间 给 你 答复 。 
| HER) [E5] — mimo RO 
E 注册 新 用 户 REES : IE 留言 主题 : 

gang. 来 自 的 朋友 在 留言 内 容 : 












































管理 回复 : 对 不 起 ， 暂 无 回复 ! 











图 6-3 留言 页 面 的 设计 效果 





IM ”数据库 设计 与 连接 


制作 留言 板 管理 系统 ， 首 先 要 设计 一 个 可 存储 访问 者 留言 内 容 、 管 理 员 对 留言 信息 的 回 
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复 以 及 管理 员 账 号 、 密 码 的 数据 库 文件 ， 以 方便 管理 和 使 用 。 


PESE 数据 库 设 计 


本 数据 库 主 要 包括 “留言 信息 意见 表 ” 和 “管理 信息 表 ” 两 个 数据 表 ,“ 留言 信 息 意见 
R” MAN gbook, “管理 信 息 表 ”命名 为 admin, 

制作 的 步骤 如 下 。 

1) 在 phpmyAdmin 中 建立 数据 库 gbook， 单 击 日 数据 库 命 令 打 开本 地 的 “数据 库 ” 管 理 页 
面 ， 在“ 新建 数据 库 ” 文 本 框 中 输入 数据 库 的 名 称 gbook ， 单 击 后 面 的 数据 库 类 型 下 拉 列 表 
框 ， 在 弹出 的 下 拉 菜 单 中 选择 utf8_general_ci 选项 ， 单 击 “ 创 建 ” 按 钮 ， 返回 “常规 设置 ” 
页 面 ， 在 数据 库 列表 中 就 已 经 建立 了 gbook 的 数据 库 ， 如 图 6-4 所 示 。 
9 127.0.0.1 / locahost | phpMyAdmin 3.5.0 -世界 之 窗 3.5 i 
4 ^ . @ € Q A Jr [D http://127.0.0.1/phpmyadmin/index.php?token=57245e73: - | 9.) [X] (39. 电 分 a] 


Y Drk 
本 127.0.0.1 7 iocahost | php… 


phpMyAdmin 
$?Óseus 




















































































(orte mm) .… IM 数据 库 
(3 bbs 
B 民 新 建 数据 库 O 
(3) informatiórl schema 
(3 member shook, utf8 general ci g ee 
(3 mysql 
数据 库 。 

(3 news — 
E E] bbs az 检查 权限 
国 performance_schema 
es D] gbook a 引 检查 权限 
Qj sakia C information schema — 8&5 检 查 权限 
@ test O member 检查 权限 
(3) vote O mysql az 检查 权限 
(3) world L] news 纪检 查 权限 

C performance schema =) 检查 权限 
http://127.0.0.1/phpmyadmin/index.php?db=gbook&token=57245e73c1092d55ba0e7b9a6b592a1b E EL Q T£ aK Q 10096 E 








图 6-4 开始 建 数据 表 


2) 单 击 左边 的 gbook 数据 库 将 其 连接 上 ， 打开“ 新 建 数据 表 ” 页 面 ,分 别 输入 数据 表 
名 gbook FI admin 〈 即 创建 2 个 数据 表 ) ， 设 计 gbook 的 字段 结构 如 表 6-2 所 示 。 输 入 字段 名 
以 及 设置 数据 类 型 的 相关 数据 ， 如 图 6-5 所 示 




















字段 名 称 数据 类 型 字段 大 小 必 填 字段 
ID INTEGER 11 Æ (自动 编号 ) 
subject VARCHAR 50 是 
content TEXT 是 
reply TEXT 
date DATE 是 















































字段 名 称 数据 类 型 字段 大 小 必 填 字段 
redate DATE 
IP VARCHAR 50 是 
passid VARCHAR 20 是 
e 127.0.0.1 / localhost / gbook / gbook | phpMyAdmin 3.5.0 - 世界 之 窗 3.5 --nmn»x 
«4» .Q, Z Q4 A Jr [D http://127.0.0.1/phpmyadmin/index.php?db=gbook&token: - |. 9] [x] | 0g. 谷歌 搜索 qa] 


Y Drk 
中 Bi 127.0.0.1 / localhost / gbo... 


phpMyAdmin Cllocalhost » fB gbook » E gbook 

















$*5 s ege 








| WM | 辐 SQL HAA (sh BSA RE x MAS 


[编辑 ] [创建 PHP 代码 ] 


操作 
































个” 全 选 /全 不 先 deum Das £^ gx Om Dis 


否 无 。 AUTO INCREMENT 多 修改 Q 删除 v 更 多 


eM # 名 字 XT 整理 Ht 空 默认 额外 
gbook M O11090 int(11) 
B admin O 2 subject varchar(50) utfà general ci 否 无 
国 gbook O 3 content text utfà general ci Sox 
O SGERdEE O 4 reply text utfà general ci 是 NULL 
oO 5 date date Sox 
[] 6 redate date 是 NULL 
E 7? IP varchar(SU) utf8 general ci 否 无 
口 8 passid varchar(20) utfà general ci E E 


2 Ek O 删除 v ES 
P ER OMR v 更 多 
s Ek @ 删除 v EZ 
P ER OMR v 更 多 
s ER OMR v 更 多 
P ER OMR v 更 多 
s € OMR v 更 多 





Te- 图 索引 





| 





& 打印 预览 d 关系 查看 

















Exil 


gem |! 个 字段 @ TRAR O 于 表 开头 O F 之 后 LD 


规划 表 结构 @ 











g 执行 























EE 9 T& e «p Q 10096 - 





6-5 





创建 的 数据 表 gbook 


3) 创建 admin 数据 表 ， 参 见 表 6-3。 用 于 后 台 管 理 者 登录 验证 ， 输 入 数据 域名 以 及 设 


置 数据 域 位 的 相关 数据 ， 如 图 6-6 所 示 。 






































































































































@ 127.0.0.1 / localhost / gbook / admin | phpMyAdmin 3.5.0 - 世界 之 窗 3.5 ze 
4 Ò. e 2 会 A i [E http://127.0.0.1/phpmyadmin/index.php?db=gbook&:tabie= ML | ES | (3. 电 分 qa | 
9 pose » 
Ga B 127.0.0.1 / localhost / gbo... 
phpMyAdmin Cllocalhost » fB gbook » E admin 
" = 国 浏览 yian SQL A 8R HAA | 图 导出 | 国 导 入 | Rf x xm 
UBODE E | M s uan | Ea E 人 
~ MySQL 返回 的 查询 结果 为 空 (MFT) ( 查询 花费 0.0008 秒 ) | 
{最近 使 用 的 表 ) M 
gbook *Y|| sgECT- 
— admin" 
EE SAID LIMITO , 30 
ix] gbook 
口 概 要 [快速 编辑 ][ 编辑 ] [解释 SQL ] [创建 PHP 代码 ] [刷新 
O SERER [i J[ JE 1[ lI ] 
# 名 字 类 型 整理 Hi 空 默认 额外 操作 
口 1 id int(11) "x JE @ 删除 v 更 多 
[] 2 username varchar(50) utfà general ci [S ci 修改 加 删除 v 更 多 司 
E] 3 password varchar(50) utB_general_ci "ox P ER O 删除 €: 
t. 全 选 /全 不 选 apm: Eaa A 修改 Ome PD xs me- Eg 
& 打印 预览 G 关系 查看 Se 规划 表 结构 e 
RGmn || | 个 字段 @ FRAR O TASA O 于 之 后 [id T ut 
n a 
=E EE 9 T& e «9 Q 1005 - 








图 6-6 创建 的 数据 表 admin 









QL+Dreamweaver 己 























d 6-3 管理 信息 数据 表 admin 
字段 名 称 数据 类 型 字段 大 小 Jp Hy m 
id INTEGER 长 整 型 
username VARCHAR 50 是 
password VARCHAR 50 是 
数据 库 创 建 完毕 ， 对 于 本 系统 而 言 的 新 技术 是 如 何 取 得 访问 者 的 IP 地址。 





(1L RE X. gbook 站 点 


在 Dreamweaver CC 中 创建 一 个 “留言 板 管理 系统 ”网 站 站 点 gbook， 由 于 这 是 PHP 数 
据 库 网 站 ， 因 此 必须 设置 本 机 数据 库 和 测试 服务 器 。 主 要 的 参数 设置 如 表 6-4 所 示 。 





























表 6-4 站 点 设置 的 基本 参数 

站 点 名 称 gbook 
本 机 根 目 录 C; \xampp \htdocs Vgbook 
测试 服务 器 C:\xampp\htdocs\ 

网 站 测试 地 址 http ;//localhost/gbook/ 

MySQL 服务 器 地 址 C; \xampp \mysql \ data \gbook 

管理 账号 /密码 root/28 [1 

数据 库 名 称 gbook 





创建 gbook 站 点 的 具体 操作 步 又 如 下 。 
1) 首先 在 C; xampp Mitdocs 路 径 下 建立 gbook WFK, WEI 6-7 所 示 ， 本 章 所 有 建立 
的 网 页 文件 都 将 放 在 该 文件 夹 下 。 





la 
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Le» | 53 X 
GO- » 计算 机 ， Acer (C:) EA » htdocs » ~ |» || ££ htdocs Pp 
: XHA SRO SEV IAM 帮助 (H) 
组 织 " ied HT 包含 到 库 中 v 共享 刻录 新 建文 件 夫 ~- E 9 
E index.php Ji news 
E [index.html Ji member 
Bb 视频 园 faviconico Js img 
am] 图 片 &)bitnami.css 
E3 文档 | ]applications.html Jo forbidden 
图 RETE (apache pb2 ani.gif J} mmServerScripts 
2 音乐 (8 apache pb2.png 
(8 apache pb2.gif 
iB apache pb.png 
uj isa (8 apache pb.gif 
Ji xampp 
i 计算 机 Ji vote 
& Acer (C) Jj restricted 
ca 本 地 磁盘 (D:) 出 phpweb 
Jeemés ca 07 
3 gbook 修改 日 期 : 2014/12/9 17:17 
| | Xx 




















6-7 





建立 站 点 文件 夹 gbook 


态 网 站 开发 从 入 门 到 精通 





2) 3&1] Dreamweaver CC, 选择 菜单 栏 中 的 “站 点 ”一 “管理 站 点 ”命令 ， 打 开 “ 管 理 


站 点 ”对 话 框 ， 如 图 6-8 Br. 








ze 


Dreamweaver 





Dreamweaver 
Dreamweaver 
Dreamweaver 
































EX Business Cat S sapis 
| 
| 




















图 6-8 “管理 站 点 ”对 话 框 





3) 对 话 框 的 上 边 是 站 点 列表 框 ， 其 中 显示 了 所 有 已 经 定义 的 站 点 。 单 击 下 边 的 “新 建 


站 点 ,” 按 钮 ， 打开“ 站 点 设置 对 象 ” 对 话 框 ， 进 行 如 下 参数 设置 。 
e“ 站 点 名 称 ”: gbook。 
e "Zu yh X E36" : C:\xampp\htdocs \gbook。 
如 图 6-9 所 示 。 




































pramese EAD EE E DAS. ENE 
T D o 2rd 
» 高 级 设 
您 可 以 在 此 处 为 Dreamweaver 站 点 选择 本 地 文件 夹 和 名 称 。 
站 点 名 称 : | gbook 
| 本 地 站 点 文件 夹 : [C:Wampp\htdocs\gbook\ 
| Lm] Ce ] 














—— » 





图 6-9 建立 gbook 站 点 


4) 单 击 列表 框 中 的 “服务 器” 选项 ， 并 单 击 “添加 服务 器 ”按钮 园 ， 打 开 “ 基 本 ” 


选项 卡 ， 进 行 如 图 6-10 所 示 的 参数 设置 。 






















: [gbook 
H zit fob 
服务 器 文件 来 : [C:wamppmtdocs æ 
wes urt: orao — — — ] 



































[ m | 





















































DS 








6-10 设置 “基本 ”选项 卡 






























PHP-MySQL4*Dreamweaver 动态 两 站 开发 从 入 门 到 精通 


e“ 服 务 器 名 称 ”: gbook。 

e“ 连 接 方法 ”: 本地/ 网络 。 

e“ 服 务 器 文件 诡 ”: C: \xampp\htdocs\。 

e "Web URL": http://127. 0. 0. 1/gbook/ o 

5) 设置 后 再 单 击 “高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 。 单 击 “ 维 护 同 
步 信 息 ” 复 选 框 ,在 “服务 器 模型 ”下 拉 列 表 项 中 选择 PHP MySQL 来 表示 是 使 用 PHP 开发 
的 网 页 ， 其 他 的 保持 默认 值 ， 如 图 6-11 所 示 。 





























































































































E z 
EXE E 自 
版 本 控 测 | | 运程 服务 器 
» Bund 区 维护 同步 信息 
保存 时 自动 将 文件 上 传 到 服务 器 
启用 文件 取出 功能 
加 打开 文件 之 前 取出 
取出 名 称 : 
| 电子 邮件 地 址 : 
| DASS 
服务 器 模型 :PHPMysat r] 
[ m ] [m ]L.4 .] | — 
| 
| | a ca "P | 
-一 — - A 














图 6-11 设置 “高 级 ”选项 卡 


6) 单 击 “ 保 存 ” 按 钮 ， 返 回 “服务 器 ”设置 对 话 框 ， 再 单 击 选择 “测试 ” 复 选 框 ， 
如 图 6-12 所 示 。 

































































一 m 
Em 您 将 在 此 位 置 选择 承 Web 上 的 页 面 的 服务 器 。 此 对 话 框 的 设置 来 自 | 
版 本 控制 Internet 服务 提供 商 (ISP) 或 Web 管理 员 。 
》 高 级 设置 ' Tenet Ib. 
x IRSE DT E AED 您 无 需 完成 此 步骤。 如 果 要 连接 到 web 并 发 

| 

| 

| E "a 























图 6-12 设置 “服务 器 ”参数 


单 击 “保存 ”按钮 ， 则 完成 站 点 的 定义 设置 。 在 Dreamweaver CC 中 就 已 经 拥有 了 刚刚 
所 设置 的 站 点 gbook。 单 击 “ 完 成 ”按钮 ， 关 闭 “ 管 理 站 点 ”对 话 框 ， 这 样 就 完成 了 Dream- 
weaver CC 测试 留言 板 管理 系统 网 页 的 网 站 环境 设置 。 



































qr 设置 数据 库 连 接 


完成 了 站 点 的 定义 后 ， 接 下 来 就 是 留言 板 管理 系统 网 站 与 数据 库 之 间 的 连接 。 网 站 与 数 (>) 
据 库 的 连接 设置 如 下 。 
1) 将 附 赠 资源 中 本 章 文件 复制 到 站 点 文件 夹 中 ， 打 开 index. php, "nfl 6-13 所 示 。 







































































































Dw XP S86) SEV EAD 修改 M) RO 命令 (QO WAO SOW WAH | ma. EH o L- 15] 
设计 ] 实时 视图 Q. sm WAHR 00000 00a " ] j ES 
indexphp x gbook - CxampphtdocsVgbook index php. rem [和 
gbook. php 
F Jaor eniem 
EF din - gbook (E:. 
EHE Connections xt 
BOE date 文人 
由 -图 images xt 
3 T admin php 9KB PHP 
F = S admin login php SKB PHP 
m book. php 10KB PHP 
CoU delbook php 8KB PHP 
CUTS index php 12KB PHP 
= reply. php 9KB PHP 
B8B gm: 808 x 395v 
[73 
[<>mm] | fs: x zJ A x ~ BI 382280 
lis css mo) 无 . do -om BOL -| 
列表 项 目 A 5 
@ s (B...) 




















图 6-13 打开 网 站 首页 


2) 单 击 选择 菜单 栏 上 的 一 “数据 库 ” 人 命令， 打开 “数据 库 ” 面 板 。 在 
“数据 库 ” 面 板 中 ， 单 击 选 择 “ + ”图 标 ， 并 在 打开 的 菜单 中 选择 “MySQL 连接 ” 命令， 
如 图 6-14 所 示 。 


i 点 的 Mam. 
. 单 击 上 面 的 + 按钮 外 建 连 接 。 





图 6-14 选择 MySQL 连接 


3) 在 “MySQL 连接 ”对 话 框 中 ， 输 入 “连接 名 称 ” 为 gbook, "MySQL 服务 器 ”名 为 
localhost, “用 户 名 ”为 root， 密 码 为 空 ， 如 图 6-15a 所 示 。 选 择 所 要 建立 连接 的 数据 库 名 
称 ， 可 以 单 击 “ 选 取 ” 按 钮 ， 浏 览 MySQL 服务 器 上 的 所 有 数据 库 。 选 择 刚 建立 的 范例 数据 
JÆ gbook， 具 体 的 设置 内 容 如 图 6-15b 所 示 。 

4) 单 击 “测试 ”按钮 ,测试 与 MySQL 数据 库 的 连接 是 否 正确 ， 如 果 正 确 则 会 出 现 一 
个 消息 框 ， 如 图 6-16 所 示 ， 这 表示 数据 库 连 接 设 置 成 功 。 









QL:-Dreamweaver 


MySQL 服务 器 : localhost | 










































































Kl6-15 设置 MySQL 连接 参数 


单 击 “ 确 定 ”按钮 ， 返 回 编辑 页 面 ， 在 “数据 库 ” 面 板 中 则 显示 绑 定 的 数据 库 ， 如 
图 6-17 所 示 。 











TE am 
E monum 

















图 6-16 设置 成 功 Ke-17 Spam e 


留言 板 管理 系统 页 面 


留言 板 管理 系统 分 前 台 和 后 台 两 部 分 ， 这 里 首先 制作 前 台 部 分 的 动态 网 页 。 


6.3.1 


在 首页 index. php 中 ， 单 击 “ 留 言 ” 链 接 时 ， 打 开 和 留言 页 面 book. php, 访问 者 可 以 在 上 
面 自由 发 表意 见 ， 但 管理 员 可 以 对 非法 或 不 文明 留言 进行 删除 、 修 改 等 。 

其 详细 制作 的 步 又 如 下 。 

1) 打开 静态 页 面 index. php ， 然 后 在 “现在 时 间 是 :” 后 面 加 一 个 PHP 代码 . 











动态 网 站 开发 从 入 门 到 精通 








<?php 
date default timezone set( Asia/Shanghai ) ; 
echo date(" Y -m -d h;i:s"); 


7» 


得 到 系统 的 当前 时 间 ， 在 文字 “留言 ”上 做 一 个 超 链 接 ， 链 接 到 book. php， 效 果 如 
Kl 6-18 所 示 。 








TÈ cwampp\htdocs\gbook\index php* NES 
gbook. php 


1 EA 5 | 资讯 ER) 
| PHPewwuxn EIN 


首页 | 新 闻 动 态 | 10096 (554) 



























































B E xc. 





图 6-18  HLAOSGR EAR] 


2) 执行 菜单 “窗口 ”一 “ 绑 定 ”命令 ， 打 开 “ 绑 定 ” 面 板 ， 单 击 “ 绑 定 ” 面 板 上 的 
按钮 因 ， 在 弹出 的 荣 单 中 选择 “记录 集 (查询 ) ”命令 ， 在 该 对 话 框 中 进行 如 下 设置 。 

。 在 “名 称 ” 文 本 框 中 输入 Rs 作为 该 “记录 集 ” 的 名 称 。 

e 从 “连接 ”下 拉 列 表 框 中 选择 连接 对 象 为 gbook。 

e 从 “表格 ”下 拉 列 表 杠 中， 选择 使 用 的 数据 库 表 对 象 为 gbook。 

e 在 “ 列 ” 单 选 按钮 组 中 选择 “全 部 ” 单 选 按钮 。 

完成 后 的 设置 如 图 6-19 所 示 。 




















输入 的 值 























X] 








6-19 设置 “记录 集 ” 对 话 村 





Ir 

































QL*Dreamweaver 动态 同 站 开发 从 入 门 到 精通 


3) 单 击 “ 高 级 ”按钮 ， 进 行 高 级 模式 绑 定 ， 在 SQL 文本 框 中 输入 如 下 代码 : 


SELECT * 
FROM gbook 


// 从 数据 库 中 选择 gbook 表 
WHERE passid =0 


// 选 择 的 条 件 为 passid 为 0 


当 此 SQL 语句 从 数据 表 gbook 中 查询 出 所 有 的 passid 字段 值 为 0 的 记录 时 ， 表 示 此 留言 
已 经 通过 管理 员 的 审核 ， 如 图 6-20 所 示 。 








名 称 : 固 ] 


连接 : ENS 





SQL: SELECT * 
FROM ebook 
WHERE passid = "U' 

















Mid 








图 6-20 输入 SQL 语句 
4) 单 击 “ 确 定 ” 按 钮 ， 完 成 记录 集 的 绑 定 ， 然 后 将 此 字段 搬入 至 index. php 网 页 的 适 
当 位 置 ， 如 图 6-21 所 示 。 


B C\xampp\htdocs\gbook\index.php* 











= 口 X 
book php x 
: [ES e nuo 资讯 k F 
: PHP, 言 管理 系统 入 您 感 兴趣 的 产品 











[meam | 





首页 | 新 闻 动态 | “信息 服务 | 信息 知识 | 信息 产业 | 法 律 顾问 | 在 线 留言 | 联系 我 们 





一 在 线 留言 现在 时 间 是 :一 





























s " 
— OO 








x 


EPR 《Rs redate} 回复 内 容 : 














图 6-21 插入 相应 字段 至 index. php 网 页 


5) 在 “管理 回复 ”单元 格 中 ， 根 据 数据 表 中 的 回复 字段 reply 是 否 为 空 ， 来 判断 管理 
是 否 访问 过 。 如 果 该 字段 为 空 ， 则 显示 “对 不 起 ， 暂 无 回复 !” 字 样 信息 ; 如 果 该 字段 不 


员 


~ 











为 空 ， 就 表明 管理 员 对 此 留言 进行 了 回复 ， 同 时 还 会 显示 回复 的 时 间 和 内 容 。 





6) 在 设计 视图 上 ， 选 中 “管理 回复 ”单元 格 ， 找 到 “对 不 起 ， 暂 无 回复 !” 字 样 ， 并 


加 入 代码 ， 如 图 6-22 所 示 。 


























拆 分 | 设计 实时 视图 O, 0 标 题 : 留言 首页 E 
*td»&nbsp;&nbsp;«?php echo $row Rs['content']; ?»«/td» 
</tr> 
</table></td> 
</tr> 





<td bgcolor-"&F3F3F3"^&nbsp; </td> 
«td height="30" bgcolor="#F3F3F3"> 管 理 回复 : </td> 
<td><table width="100%" border-"9" cellspacing="e" cellpadding="0"> 














ty( $row_Rs['reply'])) { 





m 
管理 员 在 <?php echo $row Rs['redate']; ?> 回复 内 容 : «br /> 
<?php echo $row Rs['reply']; }?></td> 

</tr> 
</table></td> 

</tr> 

<tr> 





td table tr td form . table 





if ($row Rs['reply ]- enpty( $row Rs[' reply )) { 
echo“ 对 不 起 ， EZER! 1 
else 





<tr> 动态 文本 Es. reply) 

















图 6-22 加 入 代码 


<?php 
if ( $row Rs[ reply ] = empty( $row Rs[ reply ])) | 
echo" 对 不 起 , 暂 无 回复 1" ;| ”// 如 果 reply 字段 为 空 则 显示 
else] ?> // 如 果 不 为 空 则 显示 以 下 的 内 容 
<br/> 
管理 员 在 <?php echo $row, Rsf redaté ]; ? > 回复 内 容 : <br/> 


<?php echo $row_Rs{ reply ]; |?» 


重点 提示 : 通过 if…else 条 件 判断 语句 实现 判断 的 功能 。 


7) 由 于 index. php 页 面 显示 的 是 数据 库 中 的 部 分 记录 ， 而 目前 的 设 定 则 只 会 显示 数据 
库 的 第 一 笔 数 据 ， 因 此 需要 加 入 “服务 器 行为 ”中 “重复 区 域 ”的 设 定 ， 选 择 index. php 页 


面 中 记录 的 那 一 个 表格 ， 如 图 6-23 所 示 。 


8) 单 击 “ 应 用 程序 ”面板 群 组 中 “服务 器 行为 ”面板 中 的 办 按钮 ， 在 弹出 的 菜单 
中 ,选择 “重复 区 域 ”命令 ,在 打开 的 “重复 区 域 ” 对 话 框 中 ， 设 定 显示 的 数据 选项 ， 





如 图 6-24 所 示 。 


9) 单 击 “确定 ”按钮 回 到 编辑 页 面 ， 会 发 现 先 前 所 选取 要 重复 的 区 域 左上 角 出 现 了 一 


个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设 定 。 


10) 鼠标 移 至 要 加 入 “记录 集 导航 条 ”的 位 置 ， 在 “插入 ” 栏 的 “数据 ”类 别 中 单 击 
国 工具 按钮 ， 在 弹出 的 对 话 框 中 选取 要 导航 的 记录 集 以 及 导航 的 显示 方式 ， 然 后 单 击 “ 确 


e 











wu wu w ow w 


QO O0 O © o o o o 





入 门 到 精通 















定 ” 按 钮 ， 回 到 编辑 页 面 ， 此 时 页 面 就 会 出 现 该 记录 集 的 导航 条 ， 效 果 如 图 6-25 所 示 。 
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t 如 果 你 有 什么 问题 需要 咨询 的 话 ， 请 单 击 留 言 给 我 留言 ， 我 们 会 第 一 时 间 给 你 答 夏 。 
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图 6-24 设置 “重复 区 域 ” 对话 
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RS gbook php 


首页 | 新 闻 动 态 | 
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图 6-25 加 入 “记录 集 导 航 条 ” 


11) 鼠标 移 至 页 面 表格 的 右上 角 ， 并 在 “插入 ” 列 的 “数据 ”类 别 中 , 单 击 轩 工具 按 
钮 ， 在 弹出 的 对 话 框 中 ， 选 取 要 显示 状态 的 记录 集 ， 如 图 6-26a 所 示 ， 再 单 击 “确定 ” 按 
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b) 


图 6-26 加 入 “记录 集 导航 状态 ” 


a) “Recordset NavigationStatus (记录 集 导 航 条 ) ”对 话 框 ”b) 记录 集 导航 状态 
至 此 ， 留 言 


板 的 首页 index. php 设计 完成 。 打 开 浏 览 器 ,在 地 址 栏 中 输入 http:// 
127. 0. 0. 1/gbook/index. php, ， 对 首页 进行 测试 ， 由 于 现在 数据 库 中 没有 数据 ， 所 以 测试 效果 
如 图 6-27 所 示 。 
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现在 时 间 是 : 2015-01-18 03:26:24 
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如 果 你 有 什么 问题 需要 咨询 的 话 ， 请 单 击 留言 给 我 留言 ， 我 们 会 第 一 时 间 给 你 答 冥 。 
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IDE 留言 主题 : 

















留言 内 容 : 来自 的 朋友 在 留言 内 容 : 





管理 回复 : 对 不 起 ， 暂 无 回复 ! 











图 6-27 留言 板 管理 系统 主页 测试 效果 












QL*Dreamweaver 3:58:45 54A 


本 节 将 要 制作 访问 者 在 线 留 言 功 能 ， 其 主要 技术 是 通过 “服务 器 行为 ”面板 中 的 “ 插 
入 记录 ”功能 ， 实 现 将 访问 者 填写 的 内 容 插 和 人 到 数据 表 gbook 中 。 

详细 的 制作 步 又 如 下 。 

1) 执行 菜单 “文件 ”一 “新 建 ” 命 令 ， 打开“ 新 建文 档 ” 对 话 框 ,创建 新 页 面 。 执 
行 菜单 “文件 ”一 “另存 为 ”命令 ， 将 新 建文 件 在 根 目录 下 保存 为 book. php。 

2) 供 访问 者 留言 的 静态 页 面 book php, 与 主页 面 index. php 大 体 一 致 ， 效 果 如 
图 6-28 所 示 。 





E CAxampp\htdocs\gbook\book.php -0x 
EE ebook. php 
[ 留言 管理 系统 请 输入 您 感 兴趣 的 产品 








你 的 位 置 一 留言 现在 时 间 是 : m 
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图 6-28 设计 的 book. php 页 面 效果 


3) 在 留言 板 表 单 内 部 ， 分 别 执行 3 次 “ 插 和 人 记录” 一 “表单 ”一 “隐藏 区域” 命令 。 
插入 3 个 隐藏 区 域 ， 选 中 其 中 一 个 隐藏 区 域 ， 将 其 命名 为 IP， ee DR 
如 图 6-29 所 示 。 


属性 


N Fei iet 
IP iB) C php echo $ SERVER[' REMOTE_ADDR] 47 
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图 6-29 WE IP 


< input name =" IP" type =" hidden" id ="IP" value =" <?php echo $_SERVER[ REMOTE_ 
ADDR ];?»" /> 
/自动 取得 用 户 的 TP 地 址 


4) 再 选择 另外 一 个 隐藏 区 域 命名 为 date， 并 在 “ 值 ” 文 本 框 中 输入 获取 系统 时 间 的 代 
码 如 图 6-30 所 示 。 


<input name = " date" type = "hidden" id =" date" value =" <?php 





留言 板 管理 系统 


date default timezone set( Asia/Shanghai ) ; 
echo date(" Y -m -d hii:s"); 
?>">// 获 取 系 统 即 时 时 间 


区 Fai it 
date V) Vphpdste default timezone set( | 47 
































6-30 设置 date 


5) 同样 设置 第 3 个 隐藏 区 域 的 字段 名 称 为 passid,“ 值 ”为 0， 表 示 任 何 留言 者 在 留言 
时 生成 的 passid 值 为 0， 管 理 者 可 以 根据 这 个 值 进 行 判断 ， 方便 后 面 的 管理 。 如 图 6-31 
所 示 。 


属性 
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图 6-31 设置 passid 值 为 0 


6) 单 击 “ 应 用 程序 ”面板 数目 中 的 “服务 器 行为 ”面板 中 的 四 按钮 ， 在 弹出 的 菜单 
中 选择 “搬入 记录 ”， 在 打开 的 “插入 记录 ”对 话 框 中 设置 如 下 参数 。 

e 从 “连接 ”下 拉 列 表 框 中 选择 连接 对 象 为 gbook。 

e 从 “插入 表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 gbook。 

e 在 “插入 后 ， 转 到 ”文本 框 中 输入 index. php; 

e 在 “ 列 ” 列 选项 中 会 自动 配置 相应 的 字段 插入 ， 其 中 没有 配置 的 值 是 供 管理 者 进行 




















插入 使 用 的 。 
完成 后 的 设置 如 图 6-32 所 示 。 
aR Pomik. =F 
提交 值 ， 自 : [fornl 司 | 
iei [aeos -] | Comi) 
插入 表格 : [ebook -] | 














mpi» g— DEERE 


t sour DET rs pL E 
| det v D FORM. date 获取 值 作为 “日 期 


没有 获 
ur I a m. mif 
auster i E 
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图 6-32 设置 “插入 记录 ”对 话 框 


7) 单 击 “ 确 定 ” 按 钮 ， 回 到 网 页 设计 编辑 页 面 ， 就 完成 页 面 book. php “AWE” 
的 设置 。 


Hi 















QL+Dreamweaver 


8) 有 些 访问 者 进入 留言 页 面 book. php 后 ， 不 填 任 何 数据 就 直接 把 表单 送出 ， 这 样 数据 
库 中 就 会 自动 生成 一 笔 空白 数据 。 为 了 阻止 这 种 现象 的 发 生 ， 须 加 入 “检查 表单 ”的 行为 。 
具体 操作 是 在 book. php 的 标签 检测 区 中 ， 单 击 <form1l > 这 个 标签 ， 然 后 再 单 击 “ 行 为 ” 面 
板 的 按钮 因 ， 在 弹出 的 菜单 中 ， 选 择 “ 检 查 表单 ”命令 。 

9) “检查 表单 ”行为 会 根据 表单 的 内 容 来 设 定 检查 方式 ， 留 言 者 一 定 要 填 和 人 标题 和 内 
容 ， 因 此 将 subject, content 这 两 个 字段 的 值 勾 选 “必需 的 ” 复 选 框 ， 这 样 就 可 完成 “检查 
表单 ”的 行为 设 定 了 。 具 体 设置 如 图 6-33 所 示 。 





















































pem —À =) 
input “username” (R) 
.Ey C) 
x: Cm m 

| 值 : 
可 接受 : 回 任何 东西 O 数字 
O 电子 邮件 地 址 O 数字 从 到 | 
b: J 








K 6-33 设置 “检查 表单 ”对 话 框 
单 击 “ 确 定 ” 按 钮 ， 完 成 留言 页 面 的 设计 。 


| Section | 


后 台 管理 功能 的 设计 


留言 板 后 台 管 理 系统 可 以 使 系统 管理 员 通 过 admin, login. php 进行 登录 管理 ,管理 员 登 
录 页 面 的 设计 效果 如 图 6-34 所 示 。 











函 CAxamppMhtdocsygbookyadmin login.php -0x 





BEES book php 
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图 6-34 管理 员 登 录 页 面 





COo 管理 员 登 录 页 面 


管理 页 面 是 不 允许 一 般 网 站 访问 者 进入 的 ， 必 须 受 到 权限 约束 。 

详细 操作 步骤 如 下 。 

1) 打开 制作 的 静态 页 面 admin, login. ppp。 单 击 “应 用 程序 ”面板 群 组 中 的 “服务 器 行 
为 ”面板 上 的 按钮 加 ， 在 弹出 的 菜单 中 ， 选择“ 用 户 身份 验证 /登录 用 户 ” 命 令 ， 弹 出 “ 登 





动态 网 站 开发 从 入 门 到 精通 





留言 板 管 理 系统 





录用 户 ” 对 话 框 ， 在 这 里 做 如 下 设置 : 如 果 不 成 功 ， 将 返回 主页 面 index. php; 如 果 成 功 ， 
将 登录 后 台 管 理 主页 面 admin. php， 如 图 6-35 所 示 。 





从 表单 获取 输入 : Lforml 
用 户 名 字段 : | username 
密码 字段 : |password 
使 用 连接 验证 : | ebook 
表格 :| admin 
用 户 名 列 : | username 
密码 列 : password 
| 如 果 登 录 成 功 ， 转 到 : admin. php 
| O 转 到 前 一 个 URLGD 果 它 存在 》 
| ”如果 登录 失败 ， 转 至 |: index php 

































































| ”基于 以 下 项 限制 访问 : € 用 户 名 和 密码 
| O 用 户 名 、 密码 和 访问 级 别 
获取 级 别 自 : [ia 








图 6-35 设置 “登录 用 户 ” 对 话 框 


2) 执行 菜单 “和 窗口” 一“ 行为” 命令， 打开“ 行为” 面板， 单 击 “行为 ”面板 中 的 
外 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 检 查 表单 ”命令 ， 打 开 “ 检 查 表单 ”对 话 框 ， 设 置 user- 
name 和 password 文本 域 的 “ 值 ” 都 为 “必需 的 ”"， “可 接受 ”为 “任何 东西 ” ， 如 网 6-36 
所 示 。 














input "username" (R) 
input “password” (R) 























可 接受 : 图 任何 东西 O 数字 
O 电子 邮件 地 址 ”加 数字 从 








Ir 


图 6-36 设置 “检查 表单 ”对 话 村 


3) 单 击 “确定 ”按钮 ， 回 到 编辑 页 面 ， 管 理 员 登 录入 口 页 面 admin. login. php 的 设计 
与 制作 都 已 经 完成 。 


TP Gti 


后 台 管理 主页 面 admin. php 是 管理 员 由 登录 的 页 面 验证 成 功 后 所 转 到 的 页 面 。 这 个 页 面 
提供 删除 和 编辑 留言 的 功能 ， 效 果 如 图 6-37 所 示 。 
详细 操作 步骤 如 下 。 
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bc] C: Mpachexht docs'gbook'adnin. php 
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图 6-37 “管理 主页 面 ”的 设计 效果 











站 开发 从 入 门 到 精通 


1) 打开 admin. php 页 面 ， 此 页 面 设 计 比 较 简 单 ， 在 这 里 不 做 详细 说 明 。 单 击 “ 绑 定 ” 


面板 上 的 内 按钮， 在 弹出 的 对 话 框 中 ,选择 “记录 集 (查询 )” 命 令 ， 在 打开 的 “记录 集 ” 


对 话 框 中 进行 如 下 设置 。 
。 在 “名 称 ” 文 本 框 中 输入 Rs 作为 该 记录 集 的 名 称 。 
e 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数 据 源 连 接 对 象 gbook。 
。 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 gbook。 
e 在 “ 列 ” 栏 中 选择 “全 部 ” 单 选 按钮 。 
e 设置 “排序 ”方法 为 以 ID 降序 。 
再 单 击 “ 确 定 ” 按 钮 后 就 完成 设 定 ， 如 图 6-38 所 示 。 
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图 6-38 设置 “记录 集 ” 对 话 框 


2) 绑 定 记录 集 后 ， 将 记录 集 字段 插入 至 admin. php 网 页 的 适当 位 置 ， 如 图 6-39 所 示 。 
3) admin. php 页 面 的 功能 是 显示 数据 库 中 的 部 分 记录 ， 而 目前 的 设 定 则 只 会 显示 数据 


库 的 第 一 笔 数 据 ， 需 要 加 入 “服务 器 行为 ”中 的 “重复 区 域 ”命令 ， 选 择 admin. php 页 面 


中 与 记录 有 关 的 那 一 行 表 格 ， 如 图 6-40 所 示 。 
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图 6-39 插入 字段 至 admin. php 网 页 
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村 
图 6-40 选择 要 重复 的 内 容 






















4) 单 击 “应 用 程序 ”面板 群 组 中 的 “服务 
器 行为 ”面板 上 轩 按 钮 ， 在 弹出 的 菜单 中 ， 选 
择 “ 重 复 区 域 ”命令 ， 在 打开 的 “重复 区 域 ” 
对 话 框 中 ， 设 置 一 页 显示 的 记录 数 ， 例 如 10 条 
记录 ， 如 图 6-41 E 

5) 单 击 “确定 ”按钮 ， 回 到 编辑 页 面 ， 会 

















H] 








发 现 先前 所 选取 要 重复 的 区 域 左 上 角 出 现 了 一 个 图 6-41 RE “ERKA” OA 
“重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设置 。 
6) 首先 选取 记录 集 有 记录 时 ， 要 显示 的 记录 表格 如 图 6-42 所 示 。 





E] C: \Apachethtdocs\gbooktadmin. php -0x 
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图 6-42 选择 有 记录 时 显示 页 面 












QL*Dreamweaver 动态 网 站 开发 从 入 门 到 精通 
7) 单 击 “服务 器 行为 ”面板 中 的 四 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “显示 区 域 / 如 果 记 

录 集 不 为 空 则 显示 区 域 ” 命 令 ， 在 打开 的 “如 果 记 录 集 不 为 空 则 显示 区 域 ” 对 话 框 中 ， 选 

择 “ 记 录 集 ”下 拉 列 表 框 中 的 “Rs” 选 项 ， 如 图 6-43a 所 示 ， 再 单 击 “确定 ”按钮 ， 回 到 

编辑 页 面 ， 会 发 现 先 前 所 选取 要 显示 的 区 域 左上 角 ， 出 现 了 一 个 “如 果 符 合 此 条 件 则 显示 ” 

的 灰色 卷 标 ， 这 表示 已 经 完成 设 定 ， 如 图 6-43b 所 示 。 
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求购 公司 资讯 论坛 
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: 你 的 位 置 : 管理 主页 面 
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PLAS Cu EAS table? a? UD o hi ddenr azi on? Grm! decor Io Q 100% ~|782 x 324v 58 K / 2$ Unicode (UTF-8) — ..: 








a) b) 
图 6-43 ”完成 的 设置 
“如 果 记 录 和 集 不 为 空 则 显示 区 域 ” 对 话 框 b) 完成 的 设置 页 面 





8) 输入 记录 集 没 有 记录 时 要 显示 “目前 没有 任何 留言 "， 如 图 6-44 所 示 。 


T C: wpachevht does ebook Na dnin. php* 


De ebook. php 


2 0x 
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m > 
body> <table> Ctr? <td> <table> Ctr? <td> [R] ® Q 100% — v|T82 x 324v 58 K / 2$ Unicode (UTF-B) — 


图 6-44 选择 没有 记录 时 显示 页 面 


9) 单 击 “ 服 务 器 行为 ”面板 中 的 四 按钮 ， 在 弹出 的 菜单 中 ,选择 “显示 区 域 / 如 果 记 录 
集 为 空 则 显示 区 域 ”命令 ， 在 打开 的 “如 果 记 录 (msm 
集 为 空 则 显示 区 域 ” 对 话 杠 中， 选择 “记录 集 ” 下 
拉 列 表 框 中 的 “Rs” 选 项 ， 再 单 击 “ 确 定 ” 按 钮 回 
到 编辑 页 面 ， 会 发 现 先前 所 选取 要 显示 的 区 域 左上 
角 ， 出 现 了 一 个 “如 果 符 合 此 条 件 则 显示 ”的 灰色 





























记录 集 : Rs x] 

















图 6-45 设置 “如 果 记 录 集 为 
卷 标 ， 这 表示 已 经 完成 设 定 ， 如 图 6-45 所 示 。 空 则 显示 区 域 ” 
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10) 将 光标 移 至 要 加 入 “记录 集 导 航 条 ”的 位 置 ， 在 “插入 ” 栏 的 “应 用 程序 ”类 别 
中 ， 单 击 图 工具 按钮 ， 在 弹出 的 对 话 框 中 ， 选 取 要 导航 的 记录 集 以 及 导航 的 显示 方式 ， 如 
图 6-46a 所 示 ， 然 后 单 击 “ 确 定 ”按钮 回 到 编辑 页 面 ， 会 发 现 页 面 出 现 该 记录 集 的 导航 条 ， 
如 图 6-46b 所 示 。 








* C: MipachexXht doesNgbook^a dnin. php -0x 


BAED book. php 











首页 | 新 闻 动态 | BARS | 信息 知识 | 信息 产业 | ERN 
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et | 

body? Ctable> Ctr? td» [Ctabled] [R] Q hoos — v T82 x 402v 62 K / 2# Unicode (ITT-6 — .| 
a) b) 





图 6-46 加 入 “记录 集 导 航 条 ” 
a) “记录 集 导航 条 ”对 话 框 b) “记录 集 导航 条 ”对 话 框 
11) 单 击 页 面 中 的 “回复 ”文字 ,在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 
“浏览 文件 ”图 标 ， 在 弹出 的 “选择 文件 ”对 话 框 中 ， 选 择 用 来 显示 详细 记录 信息 的 页 面 
reply. php, WEWE 6-47 所 示 。 












































i 和 名称 ; 修改 日 期 aem 大 小 
|: Creative Cloud 点 . mmServerScripts 2014/12/9 19:56 文件 去 
B TE J notes 2014/12/9 1717 xi 
| mam =| |j Connections 2014/12/9 1717 文件 夫 | 
PEE J date 2014/12/9 17:30 文件 去 
| images 2014/12/9 19:08 文件 夫 
x L1 admin.php 2011/7/12 17:43 PHP 文件 9 KB 
| B 视频 Li admin login.php 2011/7/12 17:16 PHP 文件 5 KB 
I E book.php 2014/12/9 19:54 PHP 文件 9 KB 
= gH E delbook.php 2011/7/28 15:36 — PHP 文件 8 KB 
B 文档 [E index.php 2011/7/12 10:06 PHP 文件 12 KB 
| 图 RETE 目 reply.php 2011/7/2815:22 PHP 文件 9 KB 
d EF a 
cd 
文件 名 (N): | 所 有 文件 ch ~ 


























图 6-47 选择 链接 文件 


12) 单 击 “ 确 定 ” 按 钮 ,设置 超级 链接 要 附带 的 URL 参数 的 名 称 与 值 reply. php? ID = 
<?php echo $row Rs[ ID ]; ?> ， 值 设置 如 图 6-48 所 示 。 








类 无 - BI 3822 | 
. Hl) TTE -om ERO 


=F] 单元 格 KPO -5o | 不 换行 (0) 门 、 消 景 头 色 (6) [| 
aJ ToT 50 F50 


图 6-48 “动态 数据 ”属性 设置 


13) 单 击 “确定 ”按钮 ， 回 到 编辑 页 面 ， 选 取 编辑 页 面 中 的 “删除 ”二 字 ， 在 “ 必 
性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 “ 浏 览 文件 ”图 标 ， 在 弹出 的 “选择 文件 ”对 话 
框 中 选择 用 来 显示 详细 记录 信息 的 页 面 delbook. php， 并 设置 传递 ID 参数 ， 如 图 6-49 所 示 。 























































































































camem ^ ZR 修改 日 期 类 型 大 小 
|» Creative Cloud |;  mmServerScripts 2014/12/9 19:56 文件 去 
ig 下 载 |: notes 2014/12/9 17:17 文件 去 
n m s E |: Connections 2014/12/9 17:17 xd 
35 最 后 访 问 的 位 置 L date 2014/12/9 17:39 文件 去 | 
|: images 2014/12/9 19:08 — xx 
E 国 admin.php 2011/7/12 17:43 PHP 文件 9 KB 
| ES 视频 ] admin_login.php 2011/7/12 17:16 PHP 文件 5 KB 
H |] book.php 2014/12/9 19:54 PHP 文件 9 KB 
EBR delbook.php 2011/7/28 15:36 PHP 文件 8 KB 
Bx E] index.php 2011/7/12 10:06 PHP 文件 12 KB 
| 图 REFE | reply.php 2011/7/28 15:2 PHP 文件 9 KB 
Js : 
mI 
文件 名 (N): delbook.php?ID- «?php echo $row Rs['ID']; ?>| X | 所 有 文件 e) M 














图 6-49 设置 “删除 ”的 链接 


14) 单 击 “确定 ”按钮 ， 回 到 编辑 页 面 ， 单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 需 行 
为 ”面板 上 的 号 按 钮 ， 在 弹出 的 菜单 中 选择 “用 户 身 份 验证 /限制 对 页 的 访问 ”命令 ， 在 打 
开 的 “限制 对 页 的 访问 ”对 话 框 中 ， 选择“ 如 果 访 问 被 拒绝 ， 则 转 到 admin login. php 页 
面 ， 如 图 6-50 所 示 。 

单 击 “确定 ”按钮 ， 就 完成 了 后 台 管 理 页 面 admin. php 的 制作 。 
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选取 级别 : EX... 


|| Riia MER admin login php 

















图 6-50 设置 “限制 对 页 的 访问 ”对 话 框 





留言 板 管 理 系统 








6.4.3 


回复 留言 的 功能 主要 通过 reply. php 页 面 对 用 户 留 言 进行 回复 ， 实 现 的 方法 是 将 数据 库 
的 相应 字段 绑 定 到 页 面 中 ， 管 理 员 在 “回复 内 容 ” 中 填写 内 容 ， 单 击 “ 回 复 ” 按 钮 ， 可 以 
将 回复 内 容 更 新 到 gbook 数据 表 中 ， 页 面 效果 如 图 6-51 所 示 。 


网 C: pa cheWit docs Vgbook reply. php EIE 
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mem [-.] 
n | 图 | 
[R] Q lo0% v]766 x 493v 124 K / 3 秒 | Unicode (UTF-8) — 


图 6-51 回复 留言 页 面 效 果 














动态 功能 的 制作 步骤 如 下 。 

1) 创建 reply. php 页 面 ， 并 单 击 “ 绑 定 ”面板 上 的 四 按钮 ， 在 弹出 的 选项 中 ， 选 择 
“记录 集 (查询 )” 命 令 ， 在 打开 的 “记录 集 ” 对 话 框 中 ， 进 行 如 下 设置 。 

e 在 “名 称 ” 文 本 框 中 输入 Rs 作为 
























































该 记录 集 的 名 称 。 

e 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数 
据 源 连接 对 象 gbook。 

e 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 
用 的 数据 库 表 对 象 为 gbook。 

e 在 “ 列 ” 栏 中 选择 “全 部 ” 单 选 
按钮 。 

e 设置 “筛选 ”的 方法 为 : ID = URL 
参数 ID, 











再 单 击 “ 确 定 ” 按 钮 后 就 完成 设 定 ， 
如 图 6-52 所 示 。 

2) 绑 定 记录 集 后 ， 再 将 记录 集 的 字段 插入 至 reply php 网 页 的 适当 位 置 ， 如 图 6-53 
所 示 。 


图 6-52 设置 “记录 集 ” X 
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请 输入 您 感 兴趣 的 产品 









































{Rs. ID} 号: 
iB: | {Rs. date} 





























PopfRsesubject] 
































{Rs. content} ^ ! 
ə | 
s : 
v 
| ew e aa animan ; S 
ai ji [E] 
body? <table> Ctr? <td> <table> <tr> <td> formitforni? [R] Q 100& — v|T86 x 469v 128 K/ 3% Unicode QUTF-B) — - 








图 6-53 搬入 绑 定 字段 至 reply. php 网 页 


3) 在 本 页 面 中 添加 两 个 隐藏 区 域 ， 一 个 为 redate， 用 来 设 定 回复 时 间 ， 赋 值 等 于 < ?php 
date, default, timezone, set( Asia/Shanghai ) ;echo date(" Y -m-dh:i:s");? >; 另外 一 个 是 pas- 
sid， 用 来 决定 是 否 通过 审核 的 一 个 权限 ， 赋 值 为 0 时 ， 就 自动 通过 审核 ， 如 图 6-54 所 示 。 

mi 


N Fac et 
redate ÍB(V) ai');echo date("T-m-d hii:s");?> 42 





























属性 


Fax itt 
N passid | 18) 0 - i — A 
































图 6-54 设置 “隐藏 区域 ”两 个 字段 的 属性 


4) 单 击 “服务 器 行为 ”面板 上 的 由 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 更 新 记录 ”命令 ， 
如 图 6-55 所 示 ， 用 于 根据 留言 内 容 对 数据 库 中 的 数据 进行 更 新 。 


服务 器 行为 


十 一 “文档 类 型 : PHE 





用 户 身份 验证 
XSLT 转换 
编辑 服务 器 行为 
新建 服务 器 行为... 
全 。 获取 更 多 服务 器 行为 


6-55 ”选择 “更 新 记录 ”命令 







































































^ FORM. uj ject 3 
* FORM. content. 











H à 
" passid Pu FORM. e m 


" 
提交 为 : | 整数 | 主键 


在 更 新 后 ， 转 到 : admin. php 



































Hil 





图 6-56 设置 “更 新 记录 ”对 话 框 


6) 单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 这 样 就 完成 了 回复 留言 页 面 的 设置 。 


SP 删除 留言 页 面 


删除 留言 页 面 delbook. php， 其 功能 是 将 表单 中 的 记录 从 相应 的 数据 表 中 删除 。 页 面 设 
计 效 果 如 图 6-57 所 示 ， 详 细 说 明 步 又 如 下 。 


[^| CNxampplhtdocsygbookVdelbook.php 


ERED ebook php 






























































言 标题 : | {Rs. subject} 
{Rs. content} A 
SESA [= 
留言 内 容 
回复 内 容 : | {Rs. reply} E 
h [3 E 
m E 
body B E EH 753x 36v 








图 6-57 删除 留言 页 面 效 果 


1) 打开 delbook. php 页 面 ， 单 击 “ 绑 定 ” 面 板 上 的 国 按 钮 ， 在 弹出 的 选项 中 ， 选 择 
“记录 集 (查询 ) ”命令 ， 在 弹出 的 “记录 集 ” 对 话 框 中 ， 进 行 如 下 设置 。 

e 在 “名 称 ” 文 本 框 中 输入 Rs 作为 该 记录 集 的 名 称 。 

。 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数据 源 连接 对 象 gbook。 

。 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 gbook。 
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e 在 “ 列 ” 栏 中 选择 “全 部 ” 单 选 按钮 。 
e 设置 “筛选 ”的 方法 为 ， ID =URL 参数 ID, 
再 单 击 “ 确 定 ” 按 钮 后 就 完成 设 定 ， 如 图 6-58 所 示 。 











名 称 : Rs 
连接 : | gbook 














表格 : | ebook 
列 : 图 $3 O 选 定 的 : 
























































图 6-58 设置 “记录 集 ” 对 话 框 


2) 绑 定 记录 集 后 ， 再 将 记录 集 的 字段 插 和 人 至 delbook. php 网 页 的 各 说 明文 字 后 面 ， 如 
图 6-59 所 示 。 


























* C: \Apache\htdocs\gbook\delbook. php -0x 


DT ebook php 


























{Rs. ID] 
{Rs. date} 

{Rs. IP} 

{Rs. subject} 
{Rs. content} 


















































1 010 
: 传真 : 010r12345678 


”联系 人 : 李 先 生 。 ”联系 我 们 : 1s 
«i Jii > 


<body> [R] © Q [00% — v|T85 x 469v 127 K / 3 P Unicode (UTF-8) — 


图 6-59 字段 插入 至 delbook. php 网 页 


3) 在 delbook. php 的 页 面 上 ， 单 击 “服务 器 行为 ”面板 上 的 固 按钮 ， 在 弹出 的 菜单 中 ， 
选择 “删除 记录 ”命令 ， 如 图 6-60 所 示 ， 用 于 对 数据 表 中 的 数据 进行 删除 操作 。 

4) 打开 的 “删除 记录 ”对 话 框 中 ， 设 置 效果 如 图 6-61 所 示 。 

5) 单 击 “确定 ”按钮 回 到 编辑 页 面 ， 这 样 就 完成 了 删除 留言 页 面 的 设 定 。 
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服务 器 行为 























































































十 一 文档 类 型 : PHF 

[| ERR 
重复 区 域 
显示 区 域 , 
显示 记录 计数 
动态 文本 首先 检查 是 否 已 定义 变 量 : [主键 值 | = 
插入 记录 连接 : [ebook = L má ) 
更 新 记录 表格 : [gbeok EN 
ORE , 主键 列 加 — E 数值 
用 户 身份 验证 主键 值 : [L 参数 z) ID 
XSLT 转换 WERA: $F]: admin. php 
编辑 服务 器 行为. . 
新 建 服务 器 行为. . 
获取 更 多 服务 器 行为. .. 

图 6-60 ”选择 “删除 记录 ”命令 图 6-61 设置 “删除 记录 ”对 话 框 





管理 系统 功能 的 测试 


留言 板 系 统 部 分 用 到 了 手写 代码 ， 特 别 是 留言 的 日 期 和 回复 日 期 ， 其 中 还 涉及 了 留言 者 
的 也 采集 ， 为 了 检查 开发 系统 的 正确 性 ， 需 测试 留言 功能 的 执行 情况 。 


6.5.1 前 台 留 言 测 试 


具体 的 前 台 测 试 步 又 如 下 。 
1) 打开 浏览 器 ， 在 地 址 栏 中 输入 http://127. 0. 0. 1/gbook/, 打开 index. php 文件 ， 如 
图 6-62 所 示 。 


E 360 安 全 浏览 器 7.1 [TT x 
'€ Cty http://127.0.0.1/gbook/ mS RET 
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moo. 






现在 时 间 是 : 2015-01-16 03:49:38 





fibi — dr 























用 :|  —— — Bg 
密码 | j| ; “如果 你 有 什么 问题 圳 要 咨询 的 活 ， 请 单 击 留言 给 我 留言 ， 我 们 会 第 一 时 间 给 你 管 复 。 

















Lz) [m 记录 1 到 0 ij) 
E 5^ me WEIN 
gas. WERE BANE: 





管理 回复 : 对 不 起 ， 暂 无 回复 ! 











图 6-62 首页 效果 
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2) 单 击 “ 留 言 "， 就 可 以 进入 留言 页 面 book. php, AH 6-63 所 示 。 














3602: 30/888 7.1 < xy |* -ox 

[e] e| O| fr Y http://127.0.0.1/gbook/book.php asy 
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3j H SSRS EXE = qm) AERE seaca 7 






现在 时 间 是 : 2015-01-16 03:50:00 
































APR: ] : Bgss 
EB: | | :; 感谢 您 的 访问 ， 请 留 下 您 宝贵 的 意见 ! 
WEE. MAM 最 多 为 0 个 字符 
留言 内 容 mtm d 
Lx 














带 ,号 为 必 填 字段 
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图 6-63 留言 页 面 效 果 

3) 开始 检测 留言 板 功 能 ， 在 “留言 主题 ” 栏 中 填写 “开始 检测 留言 板 功 能 , TE "RN 

言 内 容 ” 栏 中 填写 “如 果 成 功 ，gbook 数据 表 中 将 添加 刚才 写 和 的 内 容 ”。 填 写 完 后 ， 单 击 

“提交 ”按钮 提交 ， 此 时 打开 index php 页 面 ， 可 以 看 到 多 了 一 个 刚 填写 的 数据 ， 如 
图 6-64 所 示 。 
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首页 | 新 闻 动态 1 信息 服务 | 信息 知识 | 信息 产业 | HAMN | 在 线 留 言 | 联系 我 们 

你 的 位 置 -一 在 线 留 言 现在 时 间 是 : 2015-01-16 03:50:44 
Gg 留言 ; 

; ”如果 你 有 什么 问题 需要 咨询 的 话 ， 请 单 击 留 言 给 我 留言 ， 我 们 会 第 一 时 间 给 你 答 冥 。 

) (E) — vs 1 到 1 Gi D 搜索 复制 







用 户 名 : 
2 A: 




















注册 新 用 户 找 回 密码 ID 号 留言 主题 : TUS 
USIEOEN E 2 留言 内 容 :来 自 127.0.0. 1 的 朋友 在 留言 内 容 : 
测 计 用 的 内 容 





管理 回复 : 对 不 起 ， 暂 无 回复 ! 








图 6-64 向 数 据 表 中 添加 的 数据 


PME 后 台 管 理 测 试 


后 台 管 理 在 留言 板 管理 系统 中 起 着 很 重要 的 作用 ， 制 作 完成 后 也 要 进行 测试 。 操 作 步 骤 
如 下 。 









5090002020292 € (& d 

2500060606069. 0000 

OLILE EEEE 
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1) 打开 浏览 器 ， 在 地 址 栏 中 输入 http ://127. 0. 0. 1/gbook/admin_login. php， 打 开 admin 
_login. php 文件 ， 如 图 6-65 所 示 。 
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« gma|w|—|[mi x 
IEC O É Ẹ http//127.00.1/gbook/admin login.php wgjv 
>| © | Bres x |+] TS 
留言 板 管理 系统 后 台 登 录 ă 
RP: 
密码 ， 











图 6-65 后 台 管 理 入 口 


2) 在 网 页 的 表单 对 象 的 文本 框 及 密码 框 中 ,输入 用 户 名 及 密码 ， 输 入 完毕 ， 单 击 “ 登 
录 ” 按 钮 。 

3) 如 果 在 第 二 步 中 填写 的 登录 信息 是 错误 的 ， 浏览 器 就 会 转 到 主页 面 index. php; 如 果 
输入 的 用 户 名 和 密码 都 正确 ， 则 进入 admin. php 页 面 。 在 这 里 输入 前 面 数 据 库 设 置 的 用 户 
admin 和 密码 admin 时 ， 转 到 admin. php 页 面 ， 如 图 6-66 所 示 。 
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你 的 位 置 : 管理 主页 面 
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图 6-66 打开 的 留言 管理 页 面 


4) 选择 “删除 ”命令 ， 进 入 删除 页 面 delbook. php， 并 自动 将 删除 该 留言 信息 。 删 除 
留言 后 返回 留言 管理 页 面 admin. php。 

5) 在 留言 管理 页 面 选择 “回复 ”命令 (本 次 测试 选择 编号 为 2 的 留言 进行 回复 ) ， 则 
进入 回复 页 面 reply. php， 如 图 6-67 所 示 。 

6) 当 填 写 回 复 内 容 “ 这 是 测试 回复 的 " ， 并 单 击 “ 回 复 ” 按 钮 ， 将 成 功 回复 。 

至 此 ， 完 成 了 网 站 留言 板 管理 系统 的 建设 ,读者 可 以 将 其 应 用 于 实际 网 站 的 建设 。 
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图 6-67 打开 的 回复 页 面 
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本 章 主要 将 以 手写 代码 的 形式 开发 一 个 投票 管理 系统 ， 一 个 投票 管理 系统 大 体 可 分 为 3 
个 模块 : 选票 模块 、 选 票 处 理 模块 以 及 结果 显示 模块 。 投 票 管理 系统 首先 给 出 选票 选 题 ， 即 
供 投票 者 选择 的 表单 对 象 ， 当 投票 者 单 击 选择 投票 按钮 后 ， 选 票 处 理 模块 被 激活 ， 对 服务 器 
传送 过 来 的 数据 做 出 相应 的 处 理 ， 先 判断 用 户 选 择 的 是 哪 一 项 ， 把 相应 字段 的 值 加 1， 然 后 
对 数据 进行 更 新 ， 最 后 将 结果 显示 出 来 。 本 章 的 核心 在 于 开始 以 手写 代码 的 形式 实现 PHP 
页 面 的 各 种 功能 ， 真 正 提 高 读者 的 程序 编写 能 力 。 


s AATJE EI: 


主要 掌握 以 下 知识 点 


投票 管理 系统 站 点 的 设计 
投票 管理 系统 数据 库 的 规划 
计算 投票 的 方法 
防止 刷新 的 设置 








PHP-«*MySQL*Dreamweaver x 
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态 网 站 开发 从 入 门 到 精通 





设计 规划 








投票 管理 系统 可 以 分 为 3 个 部 分 的 页 面 内 容 , 一 是 计算 投票 页 面 ， 二 是 显示 投票 结果 页 
面 ， 三 是 用 来 提供 选择 的 页 面 。 本 章 制 作 的 投票 管理 系统 总 共有 4 个 页 面 ， 页 面 的 功能 与 文 


件 名 称 如 表 7-1 所 示 。 









































表 7-1 投票 管理 系统 网 页 设计 表 
需要 制作 的 主要 页 面 页 面 名 称 X 能 
开始 投票 页 面 vote. php 访问 者 开始 进行 投票 的 页 面 








计算 投票 页 面 


voteadd. php 








对 访问 者 提交 的 数据 进行 统计 并 向 数据 库 增加 数据 的 功能 页 面 

















显示 投票 结果 页 面 voteok. php 显示 投票 选项 比例 和 总 显示 投票 的 最 终 效果 页 面 
投票 失败 页 面 sorry. php 投票 失败 转向 的 页 面 


将 要 制作 的 投票 管理 系统 的 网 页 及 网 页 结构 如 图 7-1 所 示 。 












图 7-1 


voteadd.php 


投票 管理 系统 








En 


示 投 票 结果 页 面 


voteok.php sorry.php 


投票 管理 系统 网 页 结构 图 








uL 页 面 设计 规划 


根据 介绍 的 投票 管理 系统 的 页 面 设计 规划 ， 在 本 地 站 点 上 建立 站 点 文件 夹 vote， 将 要 制 
作 的 投票 管理 系统 的 文件 夹 和 文件 如 图 7-2 所 示 。 









































el 
N 
gO- b o» 计算 机 » Acer (C) » xampp » htdocs » vote » - | 好 | | 185 vote P2 
; 文件 (站 ”编辑 (E) EEV) IAM) 帮助 (H) 
min IAF” 刻录 PEHR =- ue 
Hus ^ sm i 修改 日 期 aeui 大 小 
四 nud Ji  mmServerScripts 2014/12/8 18:07 — 文件 夫 
8 文档 Ji notes 2014/12/8 18:47 。 文件 夫 
加 | REFE Ji Connections 2014/12/8 18:47 文件 去 
"ELI — ji date 2014/12/8 18:47 Xi 
点 images 2014/12/8 18:07 文件 夫 
M 计算 机 J mdb 2014/12/8 18:07 — 文件 夫 
E Acer (C) E ser. php 2011/8/4 8:54 PHP 文件 1KB 
ca HERR (D) 上 Lj vote.php 2011/8/3 17:22 PHP 文件 4 KB 
FURA (E) 国 veteadd.php 2014/12/8 18:52 — PHP 文件 2 KB 
a : 
| Lj voteok.php 2014/12/8 18:55 — PHP 文件 5 KB 
€ 网 阁 
1M DOUGLAS-PC 
JM nc on14102nc 7. 
h 。 voteok.php 修改 日 期 : 2014/12/8 18:55 创建 日 期 : 2014/12/8 18:47 
PHP 文件 大 小 : 4.10 KB 

















图 7-2 





站 点 规划 文件 夹 和 文件 


投票 管理 系统 





uou 投票 页 面 设计 


投票 管理 系统 的 页 面 共 4 个 ， 包 括 开 始 投票 页 面 、 计 算 投 票 页 面 、 显 示 投 票 结果 页 面 以 
及 投票 失败 页 面 。 计 算 投 票 页 面 voteadd. php 的 实现 方法 是 接收 vote. php 所 传递 过 来 的 参数 
后 执行 累加 的 功能 。 为 了 保证 投票 的 公正 性 ， 本 系统 根据 IP 地 址 的 唯一 性 ， 设 置 了 防止 页 
面 刷新 的 功能 。 开 始 投票 页 面 和 显示 投票 结果 页 面 的 设计 如 图 7-3 和 图 7-4 所 示 。 
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选项 调查 中 总 共有 29 参加 投票 ! 


请 你 投票 | t 本 投票 只 可 投票 一 次 















































你 投 的 选项 是 : 
© 和 LJ 
© 1 
4 m 
图 7-3 开始 投票 页 面 图 7-4 显示 投票 结果 页 面 


数据 库 设 计 与 连接 


本 节 主 要 掌握 投票 管理 系统 数据 库 的 连接 方法 。 投 票 管理 系统 的 数据 库 主 要 用 来 存储 投 


UPME S E isit 

投票 管理 系统 需要 一 个 用 来 存储 投票 选项 和 投票 次 数 的 数据 表 vote 和 用 于 存储 用 户 IP 
地 址 的 数据 表 ip。 

制作 的 步 又 如 下 。 

1) 在 phpmyAdmin 中 建立 数据 库 vote， 选 择 日 数据 库 命 令 打 开本 地 的 “数据 库 ” 管 理 页 
面 ， 在 “新 建 数据 库 ” 文 本 框 中 输入 数据 库 的 名 称 vote。 ， 单 击 打 开 后 面 的 数据 库 类 型 下 拉 菜 
单 ， 选 择 utf8_general_ci 选项 ， 单 击 “ 创 建 ” 按 钮 ， 返回 “常规 设置 ”页 面 ， 在 数据 库 列 表 
中 就 已 经 建立 了 vote 的 数据 库 ， 如 图 7-5 所 示 。 
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phpMyAdmin — Meil EE RP fa 
aeg 0 SHBKE Æ SQL Q 状态 于 HP B SE B 导入 | v 更 多 
(最 近 使 用 的 表 ) .… X N 
| IEEE 数据 库 服务 器 i 
FHa) cdcol 31 
FH) information schema zm 服 务 器 连接 排序 规则 图 。 服务 器 : 127.0.0.1 via TCP/IP 
FH) member | utf8_general_ci [7] ”服务 器 类 型 : MySQL 
司 mysql ， 服务 器 版 本 : 5.6.14 - MySQL 
si Community Server (GPL) | LE 
2 ^ " * 协议 版 本 : 10 
司 performance schema 外 观 设置 - 用 户 : root@localhost 
(B (9 phpmyadmin 服务 器 字符 集 : UTF-8 
#9 phpweb & 语言 -Language 图 : Unicode (utf8) 
pa ES | 中 文 - Chinese simplified [s] 
Ha — 9 主题 :| pmahomme 加 | 网 站 服务 器 
.字号 :| 82% [v] 
- Apache/2.4.7 (Win32) 
P 更 多 设置 OpenSSL/1.0.e PHP/5.5.6 
* 数据 库 客户 端 版 本 : libmysgl - 
mysqind 5.0.11-dev - X 

















< 





m ] , 





图 7-5 开始 创建 数据 库 


2) 单 击 左边 的 vote 数据 库 将 其 连接 上 ， 打 开 “ 新 建 数据 表 ” 页 面 ， 分 别 输入 数据 表 名 
ip 和 vote ( 即 创 建 2 个 数据 表 ) o GE ip 数据 表 (字段 结构 见 表 7-2)， 用 于 限制 重复 投票 
使 用 ， 输 入 数据 域名 以 及 设置 数据 类 型 的 相关 数据 ， 如 图 7-6 所 示 。 























7-2 ip 数据 表 
总 尽 字段 名 称 数据 类 型 字段 大 小 必 填 字段 
主题 编号 ID INTEGER 长 整 型 
投票 的 ip 地 址 voteip VARCHAR 255 是 
E 360 安 全 浏览 器 7.1 < h/t- n| x 
://127.0.0.1/phpmyadmin/#PMAURL-1:db_structure.php?db=vote&table=&server=1&tar [à ev 
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Ah 127.0.0.1 / 127.0.0.1 / vote X 
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phpMyAdmin 上 服务 器 : 127.0.0.1 > OECIET 
$008 Wt 结构 E SQL 9 搜索 O mi 图 导出 E) SA ^ Bf cs 权限 v 更 多 
| (最 近 使 用 的 表 ) … X * 操作 行 数 ”类 型 ”排序 规则 大 小 多余 
2 *- 
国 - 品 cdcol F ip Ej 浏览 eif ce 搜索 xcd. RA Qs 2 MyISAM utf8 general ci 2.2 144 
FHJ information schema KB FT 
Ha member 7] vote JWA HAH 3 X *cH xm QW 4 MyISAM utf8 general ci 2.1 
Ha mysql - ES d 
Ha news 2 张 表 总 计 6 InnoDB utf8_general_ci "m 144 |= 
FH j performance schema * 
ye t 回 全 选 / 仅 选择 多 余 — | 选中 项 : z 
e phpweb 
JOD & HH gb 数据 字典 
Hi vote 
ud 一 reae | 
jip 
vote E 
名 字 : | | 字段 数 : | | 





























图 7-6 创建 的 ip 数据 表 





3) 设计 vote 数据 表 用 于 储存 投票 的 选项 和 投票 的 数量 ， 输 入 数据 域名 以 及 设置 数据 域 
位 的 相关 数据 ， 如 图 7-7 所 示 。 对 访问 者 的 留言 内 容 做 一 个 全 面 的 分 析 ， 设 计 vote 的 字段 
结构 如 表 7-3 所 示 。 
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表 7-3 投票 数据 表 vote 





























意 X 字段 名 称 数据 类 型 字段 大 小 必 填 字段 
主题 编号 ID INTEGER 11 是 
投票 主题 item VARCHAR 50 是 
投票 数量 vote INTEGER 20 是 

E 360 安 全 浏览 器 7.1 « malw-n x 

€| G| f| * || Q|htp;//127.0.0.1/phpmyadmin/&PMAURL-3:tbl structure.php?db-vote&table-vo 







4 127.0.0.1/127.00.1/vote X 






















































































phpMyAdmin TE ENT Æ: vote 
2BONG E] 浏览 yan O SQL 2 SE X WA B Sk 图 导入 e Bf v ws | 
| (最 近 使 用 的 志 ) .… - s eomm 排序 规则 E 3R SU 操作 | 
字 性 认 
F3 cdeol E 11D int(11) 否 无 AUTO INCREMENT 修改 Q Wis Ee 
H information schema YES 3 
Ha) member [] 2 item varchar(50) utf8_general_ci Sx Q^ Qi xs | 
图- 加 mysql 也 更 多 
EHG news F] 3 vote int(20) Bx J Ek Que xs 
ŒH performance schema vE% | 
3j phpmyadmi 
zt. ipmyadmin 4 "eA žm GAI Jlr QWR xs mt- cs 
.3 phpweb pi » 
B 3 test 图 空间 gp 全 文 搜索 
EH j vote & 打印 预览 G 关系 查看 M 规划 表 结 构 O © ERR 移动 字段 
由 国 T. 得 添加 |1 | 个 字段 加 TAE © 于 表 开 头 OO 于 之 后 | [n] (执行 ) 
+H] vote + 索引 
Ha webauth 

















| | 信息 | 








图 7-7 vote 数据 表 


4) 为 了 方便 后 面 系统 开发 的 需要 ， 事 先 在 vote 数据 表 里 加 入 4 个 投票 的 数据 ， 单 击 
“浏览 ”选项 卡 ， 在 数据 表 手 动 加 入 名 为 选项 1 ~ 选项 4 四 个 选择 模式 ， 如 图 7-8 所 示 。 
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图 7-8 输入 投票 选择 









PHP-«-MySQL*Dreamweaver zb 





数据 库 创建 完毕 ， 对 于 本 系统 而 言 ， 新 技术 是 如 何 用 手写 代码 的 形式 实现 数据 库 的 查询 
以 及 插入 等 操作 。 


J 定义 vote 站 点 


在 Dreamweaver CC 中 创建 一 个 “投票 系统 ”网 站 站 点 vote， 由 于 这 是 PHP 数据 库 网 站 ， 
因此 必须 设置 本 机 数据 库 和 测试 服务 器 。 主 要 的 设置 如 表 7-4 所 示 。 


表 7-4 站 点 设置 的 基本 参数 























站 点 名 称 vote 
本 机 根 目录 C; \xampp \htdocs \vote 
测试 服务 器 C; \xampp Mitdocs V 
网 站 测试 地 址 http ;//127. 0. 0. 1/vote/ 
MySQL 服务 器 地 址 C:\xampp\mysql\data\vote 
管理 账号 /密码 root/Z8 [1 
数据 库 名 称 vote 








创建 vote 站 点 具体 操作 步骤 如 下 。 
1) 首先 在 C: \xampp\htdocs 路 径 下 建立 vote 文件 来， 如 图 7-9 所 示 ， 本 章 所 有 建立 的 
网 页 文件 都 将 放 在 该 文件 夹 下 。 
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7-9 建立 站 点 文件 夹 vote 


2) 运行 Dreamweaver CC， 选 择 菜 单 栏 中 的 “站 点 ”一 “管理 站 点 ”命令 ， 打 开 “ 管 理 
站 点 ”对 话 框 ， 如 图 7-10 所 示 。 

3) 对 话 框 的 上 边 是 站 点 列表 框 ， 其 中 显示 了 所 有 已 经 定义 的 站 点 。 单 击 下 边 的 “新 建 
站 点 ,” 按 钮 ， 打开“ 站 点 设置 对 象 ” 对 话 框 ， 进 行 如 下 参数 设置 。 





态 网 站 开发 从 入 门 到 精通 


理 系 统 








Dreamweaver 
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导入 站 点 导入 Business Catalyst 站 点 








新 建站 点 FRE Business Catalyst 站 点 














图 7-10 “管理 站 点 ” 对 话 村 





Ir 


e“ 站 点 名 称 ”: vote。 


e“ 本 地 站 点 文件 夹 ”. C:\xampp\htdocs\vote\。 
如 图 7-11 所 示 。 


T Dreamweaver 站 点 是 网 站 中 使 用 的 所 有 文 的 集合 。Dreamweaver 


. Brem E o o aan 











您 可 以 在 此 处 为 Dreamweaver 站 点 选择 本 地 文件 来 和 名 称 。 
站 点 名 称 : | vote 





本 地 站 点 文件 来 : [C:wamppytdocwott | 

















| [ 989 | C e ][ m ] 
图 7-11 建立 vote 站 点 


4) 单 击 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “添加 服务 器 ”按钮 出 ， 打开 “基本 ” 
选项 卡 ， 进 行 如 图 7-12 所 示 的 参数 设置 。 




















服务 器 名 称 : 
连接 方法 : 
i 服务 器 文件 来 : 


Web URL: 
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7-12. 设置 “基本 ”选项 卡 



























PHP*MySQL-*Dreamweaver 动态 网 站 开发 从 入 门 到 精通 





“服务 器 名 称 ”: vote。 
“连接 方法 ”: 本 地 /网 络 。 

e“ 服 务 絮 文件 夹 ”. C: \xampp\htdocs\。 

e "Web URL": http:// 127. 0. 0. 1/ vote/。 

5) 设置 后 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 。 单 击 “ 维 护 同 
步 信 息 ” 复 选 枉 ， 在 “服务 器 模型 ”下 拉 列 表 项 中 ， 选 择 PHP MySQL 来 表示 是 使 用 PHP JF 
发 的 网 页 ， 其 他 的 保持 默认 值 ， 如 图 7-13 所 示 。 






















* SRRA 区 维护 同步 信息 
O 保存 时 自动 将 文件 上 传 到 服务 器 
O 启用 文件 取出 功能 

加 打开 文件 之 前 取出 
































| 取出 名 称 : 
电子 邮件 地 址 ; 
E 
服务 器 模型: 
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图 7-13 设置 “高 级 ”选项 卡 


6) 单 击 “ 保 存 ” 按 钮 ， 返 回 “ 服 务 器 ”设置 对 话 框 ， 再 单 击 选择 “测试 ” 复 选 框 ， 
如 图 7-14 所 示 。 
































S 您 将 在 此 位 置 选择 承载 Web HEYZIRORRASSS- lineae RR 
Internet 服务 提供 商 (ISP) 或 Web 管理 员 。 

版 本 控制 

» 高 级 设置 











注意 : "T SBXSIBHDEN. z e E 
Aor ERI. 您 无 需 完成 此 步骤 。 如 果 要 连接 到 Web 并 发 


| iei | 运程 (AW | 
ABER (VI 
































图 7-14 设置 服务 器 参数 
单 击 “保存 ”按钮 ， 则 完成 站 点 的 定义 设置 。 在 Dreamweaver CC 中 就 已 经 拥有 了 刚刚 
所 设置 的 站 点 vote。 单 击 “ 完 成 ”按钮 ， 关闭“ 管理 站 点 ”对 话 框 ， 这 样 就 完成 了 Dream- 
weaver CC 测试 投票 管理 系统 网 页 的 网 站 环境 设置 。 





票 管理 系统 


uus 设置 数据 库 连接 


完成 了 站 点 的 定义 后 ， 接 下 来 就 是 投票 系统 网 站 与 数据 库 之 间 的 连接 。 网 站 与 数据 库 的 © 
连接 设置 如 下 。 
1) 将 附 赠 资源 中 本 章 静 态 文件 复制 到 站 点 文件 夹 下 ， 打 开 vote. php 投票 首页 d 


图 7-15 所 示 。 
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[<y> rm] ERO [x ~ BI 322m [pese 
Bi css ma) 无 . BHgO) -0m BRO ~ 
Rna] Qi 7| E 
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图 7-15 打开 网 站 首页 


2) 单 击 选择 菜单 栏 上 的 一 “数据 库 ” 人 命令， 打开 “数据 库 ” 面 板 。 在 
“数据 库 ” 面 板 ， 单 击 选择 “ +” 按钮， 并 在 打开 的 菜单 中 选择 “MySQL 连接 ”命令 ， 
如 图 7-16 所 示 。 


i 站 点 的 Mam. 
. 单 击 上 面 的 + 按钮 包 建 连接 。 





图 7-16 选择 MySQL 连接 
3) 在 “MySQL 连接 ”对 话 框 中 , 输入 “连接 名 称 ” 为 vote, "MySQL 服务 器 ”名 为 
localhost, “用 户 名 ”为 root， 密 码 为 空 ， 如 图 7-17a 所 示 。 选 择 所 要 建立 连接 的 数据 库 名 
称 ， 可 以 单 击 “ 选 取 ” 按 钮 浏览 MySQL 服务 器 上 的 所 有 数据 库 。 选 择 刚 建立 的 范例 数据 库 


vote， 具 体 的 设置 内 容 如 图 7-17b 所 示 。 
4) 单 击 “测试 ”按钮 ,测试 与 MySQL 数据 库 的 连接 是 否 正确 ， 如 果 正 确 则 会 出 一 个 


消息 框 ， 如 图 7-18 所 示 ， 这 表示 数据 库 连 接 设置 成 功 。 








动态 网 站 开发 从 入 门 到 精通 






































(mecum D = 
连接 名 称 :vote 
MySQL 服务 器 : localhost | 
jc rc-—— 
EB 
| SUBE vote Xm... 
一 -— 
a) 
m = - 














选取 数据 库 : 
































== 
图 7-17 设置 MySQL 连接 参数 


单 击 “ 确 定 ”按钮 ， 返 回 编辑 页 面 ， 在 “数据 库 ” 面 板 中 则 显示 绑 定 过 来 的 数据 库 ， 
如 图 7-19 所 示 。 























































A see | 绑 定 | 服务 器 行为 | — = 
MySQL 连接 O *, 一 文档 类 型 : PP c 
Dreamweaver 
连接 名 称 : v mm P Ls Q Bid 
MySQL 服务 器 : [取消 ) ig 
nit o 成 功 创建 壬 接 脚 本 。 (AW) 
密码 : Caa] | Ub item (varchar 50 必需 的 ) 
il 数据 库 : | Ta vote Gnt 20 必需 的 ) 
Aa 视图 
~ A 
图 7-18 设置 成 功 7-19 绑 定 的 数据 库 























投票 管理 系统 页 面 设计 


在 投票 管理 系统 中 ， 需 要 重点 设计 的 页 面 是 开始 投票 页 面 vote. php 和 投票 结果 页 面 
voteok. php。 计 算 投票 页 面 voteadd. php 是 一 个 动态 页 面 ， 没 有 相应 的 静态 页 面 效果 ， 只 有 
累加 投票 次 数 的 功能 。 








7)“ 开始 投票 页 面 设计 


开始 投票 页 面 vote. php 主要 是 用 来 显示 投票 的 主题 和 投票 的 内 容 ， 让 用 户 进行 投票 ， 











然后 传递 到 voteadd. php 页 面 进行 计算 。 
详细 的 操作 步骤 如 下 。 
3) 打开 刚 创建 的 vote. php 页 面 ， 输 入 网 页 标题 “开始 投票 页 面 "， 执行 菜单 “文件 ” 
存 ” 命 令 ， 将 网 页 保存 。 

2) 在 刚 创 建 背景 图 像 的 单元 格 中 ， 执 行 菜单 “插入 记录 ”一 “表单 ”一 “表单 ” 命 
令 ， 再 执行 菜单 “插入 ”一 “表格 ”命令 ,在 表单 中 插入 一 个 3 行 2 列 的 表格 ， 并 在 表格 
中 执行 菜单 “插入 ”一 “表单 ”一 “ 单 选 按钮 ” ， 插 入 一 个 单 选 按钮 ， 然 后 在 “属性 ” 面 
板 中 选择 单 选 按钮 ， 将 它 命名 为 ID ， 如 图 7-20 所 示 。 


尾 性 
GJ 单 选 按钮 选 定 值 初始 状态 O BAE C) 类 (C) 无 v 


m C sie a» 


















































图 7-20 设置 “ 单 选 按钮 ”名 称 


3) 执行 菜单 “插入 ”-、“ 表 单 ”-、“ 按 钮 ”命令 ,插入 两 个 按钮 。 一 个 是 用 来 提交 
表单 的 按钮 ， 命 名 为 “投票 "; 另外 一 个 是 用 来 查看 投票 结果 的 按钮 ,命名 为 “查看 ”。 效 
果 如 图 7-21 所 示 。 


















































d Cxampp\htdocs\vote\vote.php* = 
ERD vote. php 
: ”请 你 投票 + 4 本 投票 只 可 投票 一 次 a 
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[d 7-21 插入 两 个 按钮 效果 图 
4) 单 击 “ 应 用 程序 ”面板 群 组 中 “ 绑 定 ”面板 上 的 四 按钮 ， 在 弹出 的 菜单 中 ， 选 择 
“记录 集 (查询 )” 命 令 ， 在 打开 的 “记录 和 集 ” 对 话 框 中 ， 输 入 六 PUES 如 图 7-22 所 示 。 
rS aux : 
























| 名 称 : Rsvote | [ Weg ] 
连接 : |vote v [定义 ..…. — 











表格 : 






























































图 7-22 设置 “记录 集 ” 对 话 框 
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5) 绑 定 记录 集 后 ， 将 记录 集中 的 字段 搬 人 至 
vote. php 网 页 的 适当 位 置 ， 如 图 7-23 所 示 。 | 
6) 单 击 “ 单 选 按钮 ”将 字段 ID 绑 定 到 单 选 ， Ea 





75% (335) 


动态 网 站 开发 从 入 门 到 精通 








8696 (287) 





你 投 的 选项 是 ， 


O — (Rsvoteitem)| 





按钮 上 ， 绑 定 后 在 “ 单 选 按钮 ”的 属性 面板 中 的 
“ 选 定 值 ” 中 添加 了 插入 ID p 图 7-23 ”记录 集 的 字段 插入 至 vote. php 网 页 
， 如 图 7-24 所 示 。 
7) MA “RETH” P posu 的 命令 ， 单 击 vote. php 页 面 中 的 表格 dn 


<?php echo $row_Rsvote[ ID ] ; 


图 7-25 所 示 。 
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动态 数据 














格式 : | 无 
TUB: 《?php echo $row_Rsvote[’ ID']; ?> 




















图 7-24 ”插入 字段 到 单 选 按 钮 
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你 投 的 选项 是 


[o eese] — — — — —] 


7-25 选择 要 重复 的 区 域 


8) 单 击 “ 应 用 程序 ”面板 群 组 中 “服务 器 行为 ”面板 上 的 四 按钮 ， 在 弹出 的 菜单 中 


选择 “重复 区 域 ” 命 令 ， 如 图 7-26a 所 示 ， 在 打开 的 “重复 区 域 ”对 话 框 中 ， 设 定 一 页 显 


IR Rsvote 记录 集中 的 所 有 记录 ， 如 图 7-26b 所 示 。 
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图 7-26 设置 “重复 区 域 ” 对话 村 





Ir 




















275 CEG: 








9) 单 击 “ 确 定 ”按钮 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 重复 的 区 域 左 上 角 出 现 了 一 
个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设置 ， 如 图 7-27 所 示 。 
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图 7-27 设置 重复 后 的 效果 


10) Æ vote. php 页 面 中 ,将 鼠标 放 在 表格 中 ， 在 “标签 选择 器 ”上 单 击 «form > 标签， 
并 在 “属性 ”面板 设置 表单 <forml > 的 “动作 ”为 设置 投票 数据 增加 的 页 面 voteadd. php。 
“方法 ”为 POST， 如 图 7-28 所 示 。 


属性 


E 表单 ID 动作 |voteadd. php O BRM v| 类 (CC) 无 
- 方法 |FoST vl 编码 类 型 vi 


forml 














7-28 设置 表单 动作 


重点 说 明 : PHP $ GET X Xe $ POST X €, 

1) $ GET € €, s GET 变量 是 一 个 数组 ， 内 容 是 由 HTTP GET 方法 发 送 的 变量 名 称 
和 值 。$_CET 变量 用 于 收集 来 自 method =" get" 的 表单 中 的 值 。 从 带 有 CET 方法 的 表单 发 
送 的 信息 ， 对 任何 人 都 是 可 见 的 (会 显示 在 浏览 器 的 地 址 栏 ) ， 并 且 对 发 送 的 信息 量 也 有 限 
制 (最 多 100 个 字符 )。 在 使 用 $_CET 变量 时 ， 所 有 的 变量 名 和 值 都 会 显示 在 URL 中 。 所 
以 ， 在 发 送 密码 或 其 他 敏感 信息 时 ， 不 应 该 使 用 这 个 方法 。 不 过 ， 正 因为 变量 显示 在 URL 
中 ， 因 此 可 以 在 收藏 天 中 收藏 该 页 面 。 在 某 些 情况 下 ， 这 是 很 有 用 的 。 

2) s POST 变量 。$_POST 变量 是 一 个 数组 ， 内 容 是 由 HTTP POST 方法 发 送 的 变量 名 
称 和 值 。$_POST 变量 用 于 收集 来 自 method ="post" 的 表单 中 的 值 。 从 带 有 POST 方法 的 表 
单 发 送 的 信息 对 任何 人 都 是 不 可 见 的 (不 会 显示 在 浏览 器 的 地 址 栏 )， 并 且 对 发 送信 息 的 量 
也 没有 限制 。 

这 里 顺便 提 一 下 表单 的 验证 问题 ， 应 该 在 任何 时 候 对 用 户 输入 可 以 进行 验证 。 客 户 端的 
验证 速度 更 快 ， 并 且 可 以 减轻 服务 器 的 负载 。 但 任何 一 个 流量 很 高 以 至 于 不 得 不 担心 服务 器 
资源 的 站 点 ， 有 必要 担心 站 点 的 安全 性 。 如 果 表 单 访问 的 是 数据 库 ， 就 非常 有 必要 采用 服务 
器 端的 验证 。 在 服务 器 验证 表单 的 一 种 好 的 方式 是 把 表单 传 给 它 自己 ， 而 不 是 跳 转 到 不 同 的 
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页 面 。 这 样 用 户 就 可 以 在 同一 张 表单 页 面 得 到 错误 信息 ， 用 户 也 就 更 容易 发 现 错误 了 。 

11) 单 击 页 面 中 的 “查看 ”按钮 ， 选 择 “ 标 签 (input)” 面 板 ， 单 击 “ 行 为 ”面板 下 
的 内 按钮， 在 弹出 的 菜单 中 选择 “ 转 到 URL” 命 令 ， 如 图 7-29 所 示 。 

12) 打开 的 “ 转 到 URL” 对 话 框 ， 在 URL 文本 框 中 输入 要 转 到 的 文件 voteok. php, ， 如 
图 7-30 所 示 ， 然 后 单 击 “ 确 定 ” 按 钮 ， 完 成 “ 转 到 URL” 设 置 。 


标签 检查 器 
属性 | 行为 | E <input) 
+j- a v 
TRER 
弹出 信息 
恢复 交换 图 像 
打开 浏览 器 窗口 








































[sau — uu 
BETREF 
wee gant 
ETD 检查 表单 


打开 在 : | 
设置 文本 , 


调用 Javaseript Iud URL: voteok. php 3B... 
跳 转 菜单 
BEER 


预先 载 入 


获 职 更 多 行为 . .. 


















































图 7-29 选择“ 转 到 URL” 命 令 图 7-30 输入 “ 转 到 URL” 的 文件 地 址 


AEWA 计算 投票 页 面 设 计 


计算 投票 页 面 voteadd. php ， 主 要 方法 是 接收 vote. php. 所 传递 过 来 的 参数 ， 然 后 再 进行 
累加 计算 。 计 算 投票 页 面 voteadd. php 只 用 于 后 台 计 算 用 ， 和 希望 投票 者 在 成 功 投票 之 后 转 到 
投票 结果 页 面 voteok. php ， 只 要 加 入 代码 header( " location : voteok. php" ) ;到 voteadd. php 页 面 
就 可 以 完成 对 voteadd. php 页 面 的 制作 。 本 小 节 核 心 代码 如 下 : 





< meta http — equiv = " Content — Type" content = " text/html; charset = utf - 8" /> 
<?php 
if (empty( $. POST[ ID ]))| 
echo "您 没 选择 投票 的 项 目 " 
exit(0) ; 
1// 判 断 是 否 选择 了 返 岗 票 的 选项 
else 


| 


$ID = strval( $_POST[ ID ]); 
// MR ID 变量 为 上 一 页 传递 过 来 的 ID 值 


M" ja 


$conn = mysql connect( " localhost" ," root" , " admin" ) ; 


// 建 立 数据 库 连 接 
if ( !$conn) 


理 系 统 





die( 数据 库 连 接 出 错 : . mysql_error( ) ) ; 
| 
// 如 果 数 据 库 连接 出 错 ,显示 错误 
mysql. select db(" vote" , $conn); 
// 查 询 vote 数据 
mysql. query( " UPDATE vote SET vote = vote + 1 WHERE ID = ". $ID.""); 
// 根 据 YD. 更 新 数 表 vote, 并 自动 加 一 
mysql. close( $conn ) ; 








header(" location: voteok. php" ) ; 
// 转 到 voteok. php 
} 


重点 提示 : UPDATE 语句 用 于 在 数据 库 表 中 修改 数据 。 
语法 
UPDATE table_name 


SET column, name = new. value 


WHERE column. name = some. value 


注释 : SQL 对 大 小 写 不 敏感 ，UPDATE 与 update 等 效 。 

为 了 让 PHP 执行 上 面 的 语句 ， 必 须 使 用 mysql. query () 函数 。 该 函数 用 于 向 SQL 连接 
发 送 查 询 和 命令 。 

如 果 手 写 代码 感觉 到 困难 ， 请 打开 第 2 章 对 PHP 和 MySQL 数据 库 的 操作 章节 ， 进 行 详 
UTE 在 手写 代码 的 时 候 切 勿 心烦 ， 只 有 细心 地 写 好 每 一 行 代码 ， 方 可 以 实现 其 功 

, fir B, 


JE 显示 投票 结果 页 面 设计 


显示 投票 结果 页 面 voteok. php 主要 是 用 来 显示 投票 总 数 结果 和 各 投票 的 比例 结果 ， 静 态 
页 面 设计 效果 如 图 7-31 所 示 。 
T5 C: \Apachethtdocs\votetvoteok. php* ETT 


vote. php TY 
: ”选项 调查 中 总 共有 参加 投票 ! ^ 




















<body> (WJ ion vols x 282v K/ 1 W| Unicode Ore 
图 7-31 显示 结果 页 面 设 计 效 果 
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1) 单 击 “应 用 程序 ”面板 群 组 中 “ 绑 定 ” 面 板 上 的 轩 按 钮 ， 在 弹出 的 菜单 中 ， 选 择 
“记录 集 (查询 ) ”命令 ,在 打开 的 “记录 集 ” 对 话 框 中 ， 设 置 如 图 7-32 所 示 。 










































































图 7-32 ”设置 “记录 集 ” 对 话 框 


2) 再 次 单 击 “应 用 程序 ”面板 群 组 中 “ 绑 定 ”面板 上 的 四 按钮 ， 接 着 在 弹出 的 菜单 
中 ,选择 “记录 集 (查询 )” 命 令 ， 在 打开 的 “记录 集 ” 对 话 框 中 ， 单 击 “ 高 级 ”按钮 ， 
进入 高 级 编辑 窗口 ， 并 在 SQL 对 话 框 中 加 入 以 下 代码 : 

SELECT sum( vote) as sum 

// 选 择 vote 字段 进行 计算 合计 ,函数 sum( ) 用 于 计算 总 值 
FROM vote 

// 从 数据 表 vote 中 取出 数据 


如 图 7-33 所 示 。 
请 ë | 























































































































名 称 : S 确定 
| 连接 : [vote ~| [定义 ... ] B 
| : SELECT sun (vote) 测试 
SaL: E Ei (vote) as sum em 
E] 
变量 S 
+2 
| snn mee 
aR 视图 
mh. Mim (.smmr |] 
WHERE 

















图 7-33 设置 “记录 集 ” 对 话 框 


3) 单 击 “确定 ”按钮 ， 完 成 记录 集 的 设置 。 绑 定 记录 集 后 ， 将 记录 集中 的 字段 插 人 至 
voteok. php 网 页 中 的 适当 位 置 ， 如 图 7-34 所 示 。 





票 管理 系统 





四 C: Mpachelht docsVvote'voteok. php -Dnx 
CHA) vote phr 
| es sum) 参加 投票 ! 















{Rs vote} 票 数 
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7-34 字段 的 插入 至 voteok. php 
4) Hl ee 按钮 ， 进 入 “代码 ”视图 编辑 页 面 ， 在 “代码 ”视图 编辑 页 面 中 找到 如 
下 代码 : 
<?php echo $row_Rs{ voté ]; ?>/<?php echo $row Rsl[ sum ]; ?> 
// 相 应 百分比 的 代码 
按 下 面 步骤 修改 此 段 代码 。 
e 去 掉 “/ ”前 面 的 ? > 的 “/” 和 后 面 的 <?php echo， 得 到 代码 : 
<?php echo $row Rs[ voté ]/ $row_Rslf sum ] ?> 
e 把 « ?php echo 和 % > 之 间 的 代码 用 O 把 它 给 括 上 ， 得 到 代码 . 
<?php echo ( $row, Rs[ voté ]/ $row. Rsl[ sum ])? >% 
e 在 代码 后 面 加 入 * 100， 得 到 代码 : 
<?php echo ( $row, Rs[ voté ]/ $row Rsl[ sum ]) * 100?» 96 
e 在 代码 前 面 加 入 round, dE * 100 前 面 加 入 小 数 点 保留 位 数 4， 并 用 O 括 上 ， 得 到 
代码 : 
<?php echo round( ( $row_Rsf vote ]/ $row, Rs1[ sum ] ) ,4) * 100? >% 
5) 代码 修改 之 后 ， 因 为 控制 网 页 中 的 长 度 也 是 用 到 这 段 代 码 ， 所 以 将 这 段 代 码 进行 复 
制 ， 然 后 再 单 击 一 按钮， 切换 到 “代码 ”窗口 ， 选 择 <img > 中 的 width 的 值 将 其 代码 进行 
粘贴 ， 因 为 在 图 案 中 没有 用 到 小 数 点 的 设置 ， 所 以 将 代码 前 面 round 和 保留 位 数 4 删除 ， 得 
到 代码 为 : 
width =" < ? php echo round( ( $row_Rsf vote ]/ $row_Rsl{ sum ]),4) * 100?» " 
这 样 ， 图 像 就 可 以 根据 比例 的 大 小 进行 宽度 的 缩放 ， 设置 如 图 7-35 所 示 。 


6) 单 击 | 设计 | 按钮 ， 回 到 “设计 ”编辑 窗口 ， 加 入 “服务 器 行为 ”面板 中 “重复 区 
域 ” 的 命令 ， 选 择 voteok. php 页 面 中 需要 重复 的 表格 ， 如 图 7-36 所 示 。 
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图 7-35 设置 图 像 的 缩放 


T3 C: M pachexht docs'wotetVvroteok. php. 
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图 7-36 选择 要 重复 的 区 域 





7) 单 击 “ 应 


应 用 程序 ”面板 群 组 中 “服务 器 行为 ”面板 上 的 办 按钮 ， 在 弹出 的 菜单 中 


选择 “重复 区 域 ”命令 ， 在 打开 的 “重复 区 域 ”对 话 框 中 ， 设 定 显示 Rs 记录 集中 的 所 有 记 


录 
"Ea 


个 “重复 ”的 灰色 标签 ， 这 


如 图 7-37 所 示 。 


























区 域 ”对 话机 


图 7-37 设置 “重复 











IMI 


8) 单 击 “确定 ”按钮 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 重复 的 区 域 左 上 角 出 现 了 一 


这 表示 已 经 完成 设置 。 





9) 单 击 页 面 中 的 “返回 ”按钮 ， 选择“ 标签 (input) ”面板 ， 再 单 击 “ 行 为 ”面板 上 
的 四 按钮 ， 在 弹出 的 菜单 中 选择 “ 转 到 URL” 选 项 ,在 打开 的 “ 转 到 URL” 对 话 框 中 的 
URL 文本 框 输入 要 转 到 的 文件 “vote. php”， 如 图 7-38 所 示 。 























(sei URL i =S D 
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URL: vote.php 浏览 . .. 




















图 7-38 输入 “ 转 到 URL” 的 文件 地 址 


10) 单 击 “ 确 定 ” 按 钮 ， 完 成 显示 投票 结果 页 面 voteok. php 的 设置 。 测 试 浏览 效果 如 
图 7-39 所 示 。 
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Monito 参加 投票 











图 7-39 显示 投票 结果 页 面 的 效果 


ys 防止 页 面 刷 新 设计 


一 个 投票 管理 系统 要 求 公 平 、 公 正 的 投票 ， 不 允许 进行 多 次 投票 ， 所 以 在 设计 投票 开始 
系统 时 ， 有 必要 加 入 防止 页 面 刷 新 的 功能 。 

实现 该 功能 的 详细 操作 步骤 如 下 。 

1) 打开 开始 投票 页 面 vote. php， 把 鼠标 放 在 表单 中 ， 执 行 菜单 “插入 ”一 “表单 ”一 
“隐藏 域 ” 命令 ， 插入 一 个 隐藏 字段 votelp 。 

2) 单 击 隐藏 域 交 图标， 打开“ 属性 ”面板 。 设 置 隐藏 域 的 值 为 < ?php echo $_SERV- 
ER [ REMOTE_ADDR ];?», 

// BUS M IP 地 址 

如 图 7-40 所 示 。 
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[id 隐藏 区 域 
voteip 1B (V) <?php echo $ SERVER['REMOTE ADDE| 47 


图 7-40 设置 “隐藏 域 ” 值 


3) 将 实现 防止 刷新 的 程序 放 到 voteadd. php 页 面 里 面 ， 打 开 前 面 制作 的 计算 投票 页 面 
voteadd. php ， 在 相应 的 位 置 加 入 代码 ， 如 图 7-41 所 示 。 














19 mysql select db("vote", $con); 


te 数据 库 


[^^] C:\xampp\htdocs\vote\voteadd.php -0x 
n 1 <meta http-equiv-"Content-Type" content-"text/html; charset-utf-8" /> [4 
BN 2 <?php 
来 3 if (empty($_POST['ID'])){ 
EN 4 echo "您 没 选择 投票 的 项 目 "; 3 
<> f : E 
AM Set (0 F T 
Ei 6 F Tf 是否 选择 了 人 返 岗 票 的 选项 
EM 7 else 
I 8 上 
* 9 
{}| 10  $voteip-strval($ POST['voteip']); 
1 赋值 变 量 voteip 为 上 一 页 传递 过 来 的 voteip 值 
图 12 mysql_connect("localhost", "root","™"); 
R 13 建立 数 据 库 连 接 
14 if (!$con) 
5 
Go honnest 
Œ 16 die(' 数 据 库 连 接 出 错 : ' . mysqt error()); 
Pini l 
E 18 如 果 数 据 库 连接 出 错 ， 显 示 错 误 
ge 
Y 





fa 


21 $salzmv«snl nuierví("select * from in where vnoteidcz'" &votein MIM). 

















图 7-41 加 入 防止 刷新 的 代码 


具体 的 代码 分 析 如 下 : 


$voteip = strval( $ POSTT[ voteip ] ) ; 
// 赋 值 变量 voteip 为 上 一 页 传递 过 来 的 voteip 值 


" " " " " 3 oct 
SEY 一 > , 3, 
$con = mysql connect( " localhost" ," root" , " admin" ) ; 


// 建 立 数据 库 连 接 
if ( !$con) 
| 
die( 数据 库 连 接 出 错 : . mysql_error( ) ); 
| 
// 如 果 数 据 库 连接 出 错 , 显 示 错 误 
mysql. select. db(" vote" , $con) ; 
// 查 询 vote 数据 库 
$sql = mysql_query(" select * from ip where voteid = ". $voteip. " "); 
// VA voteid = voteip 为 条 件 查询 数据 表 ip 
$info = mysql_fetch_array( $sql) ; 
// 从 结果 集中 取得 一 行 作为 关联 数组 info 
if( $info = =true) 
// 如 果 值 为 真 ,说 明 数 据 库 中 有 IP 地 址 ,已 经 投 过 票 





投票 管理 系统 


header( " location :sorry. php" ) ; 
// 转 到 voteok. php 


exit; 


| 


else 

| 
mysql_query( " INSERT INTO ip (voteid) VALUES ( ". $voteip." )"); 
// 如 果 没 有 则 将 ip 地 址 插入 到 ip 数据 表 中 
| 


mysql. close( $con) ; 
4) 完成 防止 页 面 刷新 设置 。 当 用 户 再 次 投票 时 ， 系 统 可 以 根据 IP 的 唯一 性 进行 判断 。 
当 用 户 再 次 投票 的 时 候 ， 将 转 到 投票 失败 页 面 sorry. php, sorry. php 页 面 设 计 如 图 7-42 
所 示 。 
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对 不 起 ， 你 已 投 过 一 次 票 了 ， 请 不 要 多 次 投票 
可 主页 面 查看 结果 









































图 7-42 投票 失败 页 面 效 果 





在 sorry. php 页 面 有 两 个 页 面 链接 ,“ 回 主页 面 ”链接 到 vote. php, “查看 结果 ”链接 到 
voteok. php 。 


投票 管理 系统 设计 完成 以 后 ， 可 以 对 设计 的 系统 进行 测试 ， 按 下 (F12) 键 或 打开 浏览 
TRAIN. http ://127. 0. 0. 17 vote/vote. php ， 即 可 开始 进行 测试 。 测 试 步骤 如 下 。 

1) 打开 Dreamweaver 中 的 vote. php 文件 ， 按 下 (F12) 键 或 打开 http://127. 0. 0. 17 
vote/ vote. php, je Cc ad 投票 后 跳 转 的 结果 页 面 如 图 7-43 所 示 。 

2) 不 选择 任何 选项 ， 单 击 “ 投 票 ”按钮 ， 则 打开 提示 “您 没 选择 投票 的 项 目 ”， 如 
图 7-44 所 示 。 

3) 单 击 投票 项 “ 单 选 按钮 ”项 中 的 其 中 一 项 ， 再 单 击 “ 投 票 ”按钮 ， 开 始 投票 。 
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站 开发 从 入 门 到 精通 
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选项 调查 中 总 共有 29 参加 投票 ! 











图 7-43 ”打开 的 开始 投票 页 面 
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P [E] http://127.0.0.1/vote/votea: x 


您 没 选择 投票 的 项 目 


























图 7-44 “您 没 选择 投票 的 项 目 ”错误 提示 


4) 单 击 “投票 ”按钮 后 ， 打 开 的 页 面 不 是 voteadd. php, D Jy voteadd. php 只 是 计算 
投票 数 的 一 个 统计 数字 页 面 ， 打 开 的 页 面 是 显示 投票 结果 页 面 voteok. php, voteok. php 页 
面 是 voteadd. php 转 过 来 的 一 个 页 面 ， 效 果 如 图 7-45 所 示 A 项 的 参数 已 经 增加 ,说 明 投 
票 成 功 。 
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选项 调查 中 总 共有 30 参加 投票 ! 
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图 7-45 显示 投票 结果 页 面 效 果 
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sielen a eaaa ae S 1 : 1 投票 管理 系统 


5) 单 击 “ 返 回 ” 按 钮 ， 回 到 投票 页 面 vote. php 中 。 
6) 当 用 户 再 次 投票 时 ， 将 打开 投票 失败 页 面 sorry. php. 
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对 不 起 ， 你 已 投 过 一 次 票 了 ， 请 不 要 多 次 投票 ! 
可 主页 面 查看 结果 
































图 7-46 提示 已 经 投票 


经 过 上 面 的 测试 ， 说 明 该 管理 投票 系统 的 所 有 功能 已 经 开发 完毕 。 用 户 可 以 根据 需要 修 
改 投票 的 选择 项 ， 经 过 修改 后 的 投票 系统 可 以 适用 于 任何 大 型 网 站 的 开发 与 建设 。 





第 8 = BBS 论坛 管 理 系 统 


BBS (Bulletin Board Service， 公 告 牌 服务 ) 是 一 种 基于 Internet 的 信息 服务 系统 。 它 提 
供 了 公共 电子 白板 ， 每 个 用 户 都 可 以 在 上 面 发 布 信息 或 提出 看 法 。 本 章 将 学 习 使 用 PHP 实 
现 BBS 论坛 的 开发 方法 。BBS 论坛 通常 按 不 同 的 主题 划分 为 很 多 个 版 块 ， 按 照 版 块 或 者 栏 
目的 不 同 ， 可 以 由 管理 员 设立 不 同 的 版 主 ， 版 主 可 以 对 自己 的 栏目 或 版 块 进行 删除 、 修 改 或 


锁定 等 操作 。 


EL VAVEEZE ILU 


主要 掌握 以 下 知识 点 


掌握 BBS 论坛 系统 的 功能 页 面 规划 

建立 BBS 论坛 系统 的 数据 库 

BBS 论坛 系统 中 新 增 主题 、 删 除 主题 、 回 复 主 题 的 方法 
BBS 论坛 系统 后 台 管理 功能 的 开发 





"Cs 





重量 ”系统 的 整体 设计 规划 
BBS 主要 功能 是 通过 在 计算 机 上 运行 服务 软件 ， 人 允许 用 户 使 用 终端 程序 ， 通 过 Internet 
来 进行 连接 ， 实 现 用 户 消息 之 间 的 交互 功能 。 系 统 的 开发 比较 复杂 ， 需 要 经 过 前 期 的 系统 规 
划 。 本 章 要 开发 的 BBS 论坛 管理 系统 页 面 的 功能 与 文件 名 称 如 表 8-1 所 示 。 
表 8-1 BBS 论坛 系统 网 页 设计 表 











































































































需要 制作 的 主要 页 面 页 面 名 称 Xj) 能 
BBS 论坛 管理 系统 主页 面 index. php 显示 主题 和 回复 情况 的 页 面 
讨论 主题 内 容 页 面 content php 主要 显示 讨论 主题 和 回复 内 容 的 页 面 
新 增 讨论 主题 页 面 bbs, add. php 增加 讨论 主题 的 页 面 
回复 讨论 主题 页 面 bbs, reply. php 对 讨论 主题 进行 回复 的 页 面 
后 台 版 主 登录 入口 页 面 admin, login. php 管理 员 登 录入 口 页 面 
后 台 版 主管 理 页 面 admin. php 对 论坛 进行 管理 主要 页 面 
HERRE H H del_title. php 删除 讨论 主题 的 页 面 
HER EIA W del_reply. php 删除 讨论 回复 内 容 的 页 面 
修改 讨论 主题 页 面 upd. title. php 修改 讨论 主题 的 页 面 








下 面 要 制作 的 BBS 论坛 管理 系统 的 网 页 及 网 页 结构 如 图 8-1 所 示 。 








BBS 论坛 管理 系统 


index.php 





访问 者 登录 


bbs add. php 















admin login. php 
admin. php 
del reply. php upd title. php 


8-1 BBS 论坛 管理 系统 结构 


书局 出 页 面 整 体 设计 规划 


介绍 了 BBS 论坛 管理 系统 的 整体 设计 规划 ， 在 本 地 站 点 上 建立 站 点 文件 夹 bbs。 将 要 制 
作 的 系统 文件 如 图 8-2 所 示 。 


bbs_reply. php 





del title. php 
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QL4Dreamweaver 动态 网站 开发 从 入门 到 精通 























-| bo» 计算 机 » Acer(C) » xampp » htdocs » bbs » -|4ll #F bbs 
; 文件 (日 ”编辑 (E) EEV IRT) 帮助 (H) 
IBI Y 包含 到 库 中 v 共享 刻录 新 建文 件 夫 
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yr 收藏 夫 || _mmServerScripts MW -notes 
E Creative Cloud 上 Connections li date 
p 下 载 |; images jJ; mdb 
m su |j admin.php L.] admin login.php 
g 最 后 访问 的 位 置 Lj bbs add.php Lj bbs reply.php 
Lj content.php Lj del ref.php 
m Li del reply.php Lj del. title. php 
B 视频 |] index.php | ]upd_title.php 
图 图 片 
EA vri 

















图 8-2 站 点 规划 文件 


8.1.2 页 面 美 工 设计 


BBS 论坛 管理 系统 的 界面 要 求 简 洁 明了 ， 尽 量 不 要 使 用 过 多 的 动画 和 大 图 片 ， 这 样 可 以 
提高 BBS 论坛 的 访问 速度 。 要 制作 的 首页 面 和 详细 内 容 页 面 效 果 如 图 8-3 和 图 8-4 所 示 。 
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le) 测试 新 增 主题 nin " 2011-08-07 s pue | 
L-— | 一 一 二 十 人 
B | | D b 2015-01-18 
mex | | - LL c 














图 8-3 首页 的 美工 效果 


重点 提示 : 初学 者 在 设计 制作 过 程 中 ， 可 以 打开 附 赠 资源 中 的 源 代 码 (code 文件 夹 )， 
找到 本 章 的 images 文件 夹 ， 其 中 有 已 经 编辑 好 的 图 片 。 











E 360 实 全 浏览 器 7.1 < y |#|- |O] x 


| $i CE e |* UJ http://127.0.0.1/bbs/content.php?bbs id-2 BO iv 
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， ”PHP 论坛 管理 系统 ;让 S 


主题 内 容 : 这 是 测试 用 的 ， 再 斌 








回复 内 容 : 这 是 测试 回复 的 














图 8-4 详细 内 容 页 面 效 果 


Section | 
数据 库 设计 与 连接 


制作 BBS 论坛 管理 系统 的 数据 库 需 要 根据 开发 的 系统 大 小 而 定 ， 下 面 要 设计 用 于 BBS 
进行 管理 的 信息 表 admin。 


JOE SE iit 
首先 建立 一 个 名 称 为 bbs 的 数据 库 ， 并 在 里 面 建 立 管 理 员 管 理 信息 表 admin、 讨 论 主题 
信息 表 bbs_main 和 回复 主题 信息 表 bbs_ref， 这 3 个 数据 表 将 作为 任何 数据 的 查询 、 新 增 、 
修改 与 删除 的 后 端 支持 。 
制作 的 步 又 如 下 。 
1) 在 phpmyAdmin 中 建立 数据 库 bbs, Hio seeme, ITAR RE” E 
面 ， 在 “新 建 数据 库 ” 文 本 框 中 输入 数据 库 的 名 称 bbs， 单 击 后 面 的 数据 库 类 型 下 拉 列 表 
框 ， 在 弹出 的 下 拉 菜 单 中 选择 utf8_general_ci 选项 ， 单 击 “ 创 建 ”按钮 ， 返 回 “ 常 规 设置 ” 
页 面 ， 在 数据 库 列表 中 就 已 经 建立 了 bbs 的 数据 库 ， 如 图 8-5 所 示 。 
2) 单 击 左边 的 bbs 数据 库 将 其 连接 上 ， 打 开 “ 新 建 数据 表 ” 页 面 ， 分 别 输入 数据 表 名 
admin, bbs main 以 及 bbs_ref， 即 创建 3 个 数据 表 ， 如 图 8-6 所 示 。 
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4d 127.0.0.1 / 127.0.0.1 | php. X 















































phpMyAdmin ETENE ALL : : : : : 
$saeec)e (3 SHREK Æ SQL (& 状态 呵 用 户 图 导出 G 导入 ARE | S v 更 多 
| (最 近 使 用 的 未 ) — [s] - | 
| EXE 数据 库 服务 器 | 
bbs 
EH cdcol N zm 服务 器 连接 排序 规则 g: * 服务 器 : 127.0.0.1 via TCP/IP 
FHG) gbook | utf& general ci z]! - 服务 器 类 型 : MySQL zl 
8-3 information schema ”服务 器 版 本 : 5.6.14 - MySQL 
下 -3 member e imi (GPL) 
n - WREE: 
E E 外 观 设置 * ĦA: root@localhost 
m e ach - 服务 器 字符 集 : UTF-8 Unicode (utf8) 
es E eie & 语言 - Language 图 :| 中 文 Chinese simplified - | E 

















H 习 phpmyadmin 

围 -3 phpweb ET] 主题 :| pmahomme | v | 一 

人 eem 网 站 服务 器 

< 字 呈 :| 82% [v] 

G-a vote Apache!2.4.7 (Win32) 

3 r, aci 4. in, 

EG webauth p 更 多 设置 OpenSSL/1.0.1e PHP/5.5.6 

， 数 据 库 客户 端 版 本 : ibmysql - 
mysqlnd 5.0.11-dev - 20120503 - 
Sld: 
40933630edef551dfaca71298a83fad8 
$ 

* PHP 扩展 : mysqli @ 
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图 8-5 开始 建 数 据 表 
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phpMyAdmin RA: 127.0.0.1 » 图 数据库: bbs ] à J E z ^ 
2B ONE y 结构 E SQL A SE O 查询 BS E SA ARF aR v 更 多 
| (最 近 使 用 的 未 ) - zl Xo RF 行 数 类 型 。 “排序 规则 大 多 
9 小 R 
pa bbs F] admin 国 浏 览 统 结 构 cp 搜索 了 插入 RAT OM 1 MyISAM utf8_general_ci 2 - 
es cdcol m | 
FHG gbook [] bbs main 辐 浏 览 yA $ Sx 了 插入 $e dz QUNM ”2 MyISAM utf8 general ci 2.3 - 
H 习 information schema - KB 
FH member 回 bbs ref EHAA MAA Q 搜索 Rodi. RAT QUIS 2 MyISAM utf8 general ci 2.2 - |} 
KB 
8- | 
3 张 表 总 计 5 InnoDB utf8_general_ci 6.5 2 3 
$-a performance_schema s 节 
e .3j phpmyadmin 
EH phpweb t 回 全 选 。 | 选中 项 : - 
GHJ test 
用- vote & 打印 预览 gà 数据 字典 
Ha webauth 
| i aaaea | 
名 字 : | 字段 数 : | 
EN 








图 8-6 创建 3 个 数据 表 


3) bbs main 是 用 于 存储 论坛 的 主题 表 ， 输 入 数据 名 并 设置 相关 数据 (如 图 8-7 所 示 ) ， 
对 访问 者 的 留言 内 容 做 一 个 全 面 的 分 析 ， 设 计 bbs main 的 字段 结构 如 表 8-2 所 示 。 


表 8-2 讨论 主题 信息 表 bbs main 











字段 名 称 数据 类 型 字段 大 小 
bbs_ID INTEGER 11 
bbs_title VARCHAR 20 
bbs_content TEXT 










































































































































































字段 名 称 数据 类 型 字段 大 小 
bbs_name VARCHAR 20 
bbs time VARCHAR 20 
bbs face VARCHAR 20 
bbs sex VARCHAR 20 
bbs email VARCHAR 20 
bbs ud VARCHAR 20 
bbs hits INTEGER 11 
B 3602: 230888 7.1 « gui - x 
€ ||€ || f& |x | htp//127.00.1/phpmyadmin/&PMAURL-4:tbl structure.php?db-bbs&table-bbs main&serv [2 f$ |v 
di, 127.0.0.1 / 127.0.0.1 / bbs ; X E 
phpMyAdmin O ARAS: 127.0.0.1 > @ HEE: bbs » EXT 
$890)q 国 浏览 H an O SQL à SE X IA 图 导出 图 导入 Bf vv 更 多 
| (最 近 使 用 的 表 ) ! - # BF 类 型 排序 规则 E 空 默认 WO 操作 
B-a bbs 7] 1 bbs ID int(11) E 无 AUTO INCREMENT ,修改 QNS 也 更 多 
d id 7] 2 bbs title ^ varchar20) utf8 general ci 否 Æ 2 修改 QNS 更 多 
MES Sici F 3 bbs content text utí8 general ci 是 NULL P Eh GNE 89 上司 
E bbs_ref 4 bbs name varchar(20) utf8 general ci S 无 2 修改 OMR 55 
EH edcol 5 bbs time varchar(20) utf8 general ci 否 无 让 修改 QNS 59 
Ha gbook ^ 
ŒG information schema 7] 6 bbs face varchar(20) utf8 general ci 否 Æ 修改 QNS 也 更 多 
8H I member F] 7 bbs sex varchar(20) utf8 general ci 否 无 多 修改 QNS 52 
2s mes 7j 8 bbs email varchar(20) utf8 general ci — Z Æ 2 ëk ONES vg | 
"ie performance schema F 9 bbs ur varchar(20) utf8 general ci 否 无 P Èk QNe59 
S-a phpmyadmin ^] 10 bbs hits int(11) BE ER ON 55 
ea phpweb 
ŒH test t £i EON 国 浏览 S fk OMR it mee- Eg 
GEH vote 区 空间 “ 财 全 文 搜索 
ŒH webauth 
s & 打印 预览 唱 Xxs8gb 规划 表 结构 图 © ERR 移动 字段 
sem |1 | 个 字段 加 FAAR 日 FARA OO 于 之 后 | bbs ID [| (Mi 
+ 索引 到 
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图 8-7 bbs main 数据 表 
4) 回复 主题 信息 表 bbs_ref 字段 采用 如 表 8-3 所 示 的 结构 。 设 计 后 的 数据 表 如 图 8-8 


表 8-3 回复 主题 信息 表 bbs ref 


























字段 名 称 数据 类 型 字段 大 小 
bbs main, ID INTEGER 11 
bbs_ref_ID INTEGER 自动 编号 
bbs_ref_name VARCHAR 20 
bbs ref time VARCHAR 20 
bbs ref content TEXT 
bbs ref sex VARCHAR 20 
bbs ref url VARCHAR 20 
bbs ref email VARCHAR 20 









































































































































6 3602: 388 7.1 « mew 一 C x 
€ ||& A || * || © htp//127.0.0.1/phpmyadmin/ZPMAURL-6:tbl structure.php?db-bbs&table-bbs ref&server [& f$ || 
Aù 127.0.0.1 / 127.0.0.1 / bbs 
H B 务 器 .0. 数据 | B e 
phpMyAdmin [LE 127.0.0.1 » @ #tiR E: bbs » E Æ: bbs_ref i E 
OBonse B 浏览 H an E SQL 又 搜索 EM B oth o m) SA Bf v 更 多 
| EME) - zi # 名 字 Am 看 Fl EOS NO 操作 
(£j bbs F 1 bbs main ID int(11) mox P ek OMR vE] 
3 s =) 2 bbs ref ID int(11) A Æ AUTO INCREMENT 4? 修改 QNA vE 
ep paga F] 3 bbs ref name — varchar(20) utf8 general ci 否 无 P Ea Que vE 
EH] bbs ref 门 4 bbs ref time — varcha(20) utf general ci — Z 无 EB ON m. 
& a n F 5 bbs ref content text utf8 general ci Æ NULL P Èk QS 3: 
Ha gbool i 
a 3 information schema T) 6 bbs ref sex varchar(20) utf8 general ci Sox J ER OMR vE | 
于 -本 member F] 7 bbs ref url varchar(20) utf8 general ci Sox J den QM vE? 
GA mysql T] 8 bbs ref email — varchar(20) utf8 general ci 5 Æ ER ON vm] 
La 司 news 
Bem eee nur t Dèt sem OAA Jek OMR xs m- 5R 
a phpmyadmin 夺 空间 m 全 文 搜索 
iro) phpweb 
ea test & 打印 预览 唱 关系 查看 M 规划 表 结 构 © ERAJ 移动 字段 
G-A vote 3m |1 | 个 字段 回 FRAR © 于 未 开头 OCT 之 后 | bbs_main_ID | (执行 
国 - webauth — — Mt 
+ 索引 
pem | LIS 
qi - m = Jg ' 





图 8-8 bbs ref 数据 表 


5) 最 后 设计 用 于 后 台 登 录 管理 的 admin 数据 表 ， 字 段 采用 如 表 8-4 所 示 的 结构 。 设 计 


后 的 数据 表 如 图 8-9 所 示 。 


表 8-4 管理 员 管 理 信息 表 admin 















































































































字段 名 称 数据 类 型 字段 大 小 
ID INTEGER 11 
username VARCHAR 20 
password VARCHAR 20 
E 360 安 全 浏览 器 7.1 
EA) A [Oht \URL-8:tbl 
phpMyAdmin aL à ; : : 
$aecje [E] 浏览 M 结构 LJ SQL A $E 了 插入 图 导出 E SA ^ Sf v 更 多 
| (最 近 使 用 的 表 ) .… - | s 名 字 类 型 排序 规则 属性 空 RU 额外 操作 
ER 11D int(11) A Æ AUTO INCREMENT cp 修改 @ We 人 更 多 
Era A ©] 2 username varchar(20) utf8 general ci 否 无 6P 修改 OMR 25 
tE admin 3 password varchar(20) utf8_general_ci 否 无 GP de QM 52 
GHE] bbs main : : 
HE bbs ref t E£$& em AA s ER S Q Wi 5 xi m- xS 
-3 cdcol [e 空间 (p 全 文 搜索 3 
(B 9 obook & mw d 关系 查看 M 规划 夫 结 构 © EBRD BIFA 
ŒH 9 information schema — 天 
6-3 member gä | 1 个 字段 回 FRAR © FAFA © 于 之 后 | ID =| (执行 ) 
ea mysql + 索引 
Ha news [xm 
H performance schema | 信息 | 
EH 司 phpmyadmin 
a Phpweh 已 用 空间 Row statistics 
国 -@ test — " 
H3 vote 数据 20 字 节 格式 动态 | 
EH j webauth 索引 2 KB 排序 规则 utf8 general ci F 
总 计 2 KB frit 1 
TKE 20 字 节 
行 大 小 2,068 字 节 
下 一 个 自 增值 Z E 











图 8-9 后 台 管 理 admin X 


BBS 论坛 管理 系统 





数据 库 创 建 完毕 后 ， 在 后 台 管 理 数据 表 admin 里 输入 用 户 名 和 密码 ， 以 方便 后 面 登录 查 
询 使 用 。 


SELL 定义 bbs 站 点 e 


在 Dreamweaver CC 中 创建 一 个 “论坛 管理 系统 ”网 站 站 点 bbs， 由 于 这 是 PHP 数据 库 
网 站 ， 因 此 必须 设置 本 机 数据 库 和 测试 服务 器 ， 主 要 的 设置 如 表 8-5 所 示 。 


























表 8-5 站 点 设置 的 基本 参数 

站 点 名 称 bbs 
本 机 根 目录 C; \xampp Mitdocs Vbbs 
测试 服务 器 C:\xampp\htdocs\ 

网 站 测试 地 址 http ;/127. 0. 0. 1/bbs/ 

MySQL 服务 器 地 址 C:\xampp\mysql\data\bbs 

管理 账号 /密码 root/ 空 白 

数据 库 名 称 bbs 





创建 bbs 站 点 具体 操作 步 又 如 下 。 
1) 首先 在 C: \xampp\htdocs 路 径 下 建立 bbs 文件 夹 ， 如 图 8-10 所 示 ， 本 章 所 有 建立 的 
网 页 文件 都 将 放 在 该 文件 夹 下 。 





















































f EI 
GO Lo» 计算 机 》Acer(C:)) > xampp » htdocs » - | 好 | | £85 htdocs p | 
; XHA ”编辑 (E) EEV) IAT) #8(H) 
组 织 BHF ë 包含 到 库 中 ” 共享” 刻录 新 建文 件 夫 加 ~ [M @ 
Bus z [l index.php Ji xampp |;  mmServerScripts 
ie] 图片 [J index.html Ji vote 
B 文档 园 faviconico È restricted 
&j REFE i | bitnami.css Ji phpweb 
AER [ | Japplications.html Jj; news 
if apache pb2 anigif — |, member 
"ET I3 iB apache pb2.png J img 
E Acer (C) | apache pb2.gif li gbook 
apache pb.png |; forbidden 
ca ABER (D) iE apache pb.gif | bbs | 
cs 本 地 磁盘 E) ~ amp 
bbs 。 修改 日 期 : 2014/12/10 8:48 
| | Xd 
i A 








图 8-10 建立 站 点 文件 夹 bbs 


2) 运行 Dreamweaver CC， 选 择 菜单 栏 中 的 “站 点 ”一 “管理 站 点 ”命令 ,打开 “管理 
站 点 ”对 话 框 ， 如 图 8-11 所 示 。 

3) 对 话 框 的 上 边 是 站 点 列表 框 ， 其 中 显示 了 所 有 已 经 定义 的 站 点 。 单 击 下 边 的 “新 建 
站 点 ,” 按 钮 打开“ 站 点 设置 对 象 ”对 话 框 ， 进 行 如 下 参数 设置 。 

e“ 站 点 名 称 ”: bbs, 

e。“ 本 地 站 点 文件 夹 ”: C; \xampp\htdocs\bbs\。 








动态 网 站 开发 从 入 门 到 精通 

















Dreamweaver 





Dreamweaver 





Dreamweaver 


Dreamweaver 











导入 站 点 导入 Business Catalyst 


新 建站 点 JRE Business Catalyst 站 点 











Co] 





如 图 8-12 所 示 。 





图 8-11 


“管理 站 点 ”对 话 框 








人 站点 设 轩 对 铺 bbs 

















Dreamweaver 站 点 是 网 站 中 使 用 的 所 有 合 。Dreamweaver 


ES 5 n 


您 可 以 在 此 处 为 Dreamweaver 站 点 选择 本 地 文件 夹 和 名 称 。 
站 点 名 称 : 
本 地 站 点 文件 来 ; 








4) 单 击 列表 框 中 的 “服务 器 ”选项 ， 


bbs 














C:\xampphtdocs\bbs\ 











图 8-12 建立 bbs 站 点 


选项 卡 ， 进 行 如 图 8- A 


并 单 击 “添加 服务 器 ”按钮 转 ， 打开“ 基本 ” 




















服务 器 名 称 : 
连接 方法 : 
服务 器 文件 赤 : 
won; 














C: Xxampphtdocs 







































































DS 











8-13 设置 “基本 ”选项 卡 

















“服务 器 名 称 ”: bbs. 
“连接 方法 ”: 本 地 /网 络 。 


BBS 论坛 管理 系统 


o “IRIA”: C; \xampp \htdocs\。 


e "Web URL": http://127. 0. 


5) 设置 后 再 单 击 “高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 。 单 击 “维护 同 
步 信息 ” 复 选 框 ， 在 “服务 器 模型 ”下 拉 列 表 项 中 选择 PHP MySQL 来 表示 是 使 用 PHP 开发 


0. 1/ bbs/, 





的 网 页 ， 其 他 的 保持 默认 值 ， 如 图 8-14 所 示 。 





























取出 名 称 : 
电子 邮件 地 址 : 


[VI 维护 同步 信息 

O 保存 时 自动 将 文件 上 传 到 服务 器 
O 自用 文件 取出 功能 

M 打开 文件 之 前 取出 


























测试 服务 器 








maa [rem v] 
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6) 单 击 “保存 ”按钮 ， 返回 
tW 8-15 所 示 。 





8-14 设置 “高 级 ”选项 卡 


“服务 器 ”设置 对 话 框 ， 再 单 击 选择 “测试 ” 复 选 框 ， 


















































» ”高 级 设置 








[sas bbs P x x =s) 
s 您 将 在 此 位 置 选择 承 喜 web. H'YIEIRASSS- WHETER 
FEST Internet 服务 提供 商 (ISP) 或 Web 管理 员 。 


p E 要 开始 在 Sa 下 zu faz chhuE Ro SDSRSEERERI web 并 发 


您 只 需 定义 一 个 远 


| iei ome mt | 
本 地 /网络 MI M 






































8-15 设置 “服务 器 ”参数 























单 击 “保存 ”按钮 ， 则 完成 站 点 的 定义 设置 。 在 Dreamweaver CC 中 就 已 经 拥有 了 刚才 
所 设置 的 站 点 bbs。 单 击 “ 完 成 ”按钮 ， 关闭 “管理 站 点 ”对 话 杠 ， 这 样 就 完成 了 Dream- 
weaver CC 测试 论坛 管理 系统 网 页 的 网 站 环境 设置 。 









QL+Dreamweaver 





动态 网 站 开发 从 入 门 到 精通 





uL 设置 数据 库 连 接 


完成 了 站 点 的 定义 后 ， 接 下 来 就 是 BBS 论坛 管理 系统 网 站 与 数据 库 之 间 的 连接 。 网 站 


与 数据 库 的 连接 设置 如 下 。 
1) 将 附 赠 资 源 中 本 章 文 件 复制 到 站 点 文件 夹 下 ， 打 开 BBS Y 
图 8-16 所 示 。 


仑 坛 首页 index. php, Jl 
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les, bbs. bbs, Nane] [rs bbs. Returniun] [rs bbs. LatesTi 
目前 没有 发 表 任何 主题 
Copyright @ 2011 www.hbculture.com Inc.All rights reserved. 论坛 之 家 
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8-16 打开 论坛 首页 


2) 单 击 选择 菜单 栏 上 的 “窗口 ”一 “数据 库 ” 命 
令 ， 打 开 “ 数 据 库 ”面板 。 在 “数据 库 ” 面 板 ， 单 击 选 
择 “+” 按 钮 ， 并 在 打开 的 菜单 中 选择 “MySQL 连接 ” 
命令 ， 如 图 8-17 所 示 。 

3) 在 弹出 的 “MySQL 连接 ”对 话 框 中 , DA "XE 
IZAR” H bbs, "MySQL 服务 器 ”名 为 localhost，“ 用 
户 名 ”为 root， 密 码 为 空 。 选 择 所 要 建立 连接 的 数据 库 


图 8-17 


] 点 的 测试 服务 器 。 
. 单 击 上 面 的 + 按钮 创建 连接 。 








命令 


选择 “MySQL 连接 ”外 


名 称 ， 可 以 单 击 “选取 ”按钮 ， 浏 览 MySQL 服务 器 上 的 所 有 数据 库 ， 如 图 8-18a 所 示 。 选 


择 刚 建立 的 范例 数据 库 bbs， 具 体 的 设置 内 容 如 图 8-18b 所 示 。 
4) 单 击 “ 测 试 ” 按 钮 ， 
个 消息 框 ， 如 图 8-19 所 示 ， 这 表示 数据 库 连 接 设置 成 功 。 


测试 与 MySQL 数据 库 的 连接 是 否 正 确 ， 如 果 正 确 ， 


则 会 出 一 


单 击 “确定 ”按钮 ， 则 返回 编辑 页 面 ， 在 “数据 库 ” 面 板 中 则 显示 绑 定 过 来 的 数据 库 ， 


如 图 8-20 所 示 。 
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E Ex) 
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MySQL 服务 器 : localhost | 
| 用 PE rot —— 
gu O OOO 
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图 8-18 设置 MySQL 连接 参数 






















































ser BERST E] 
+t 一 文档 类 型 : PP e 
Dreamweaver 
: 取消 MO ID Gnt 11 GRR) 
o 成 功 创建 连接 脚本 。 sut (00 i password (varchar 20 必需 的 
Bi Pod Ta username (varchar 20 必需 的 
密码 : | NN f EH bbs main 
SR. i Bü bbs ref 
数据 库 : b B 视图 
| | | < i | » 
图 8-19 设置 成 功 图 8-20 绑 定 的 数据 库 





在 Dreamweaver 中 定义 站 点 ， 建 立 数据 库 连 接 后 ， 就 可 以 进入 PHP 网 页 页 面 的 设计 阶 
段 。 首 先 制 作 最 重要 的 首页 index.php, index. php 页 面 主要 显示 所 有 的 讨论 主题 和 最 新 回复 
的 一 些 信 息 。 


uL BBS 论坛 管理 系统 主页 面 


BBS 论坛 管理 系统 的 主页 面 index. php 显示 所 有 的 讨论 主题 、 每 个 主题 的 点 击 数 、 回 复 
数 以 及 最 新 回复 时 间 。 访 问 者 可 以 单 击 要 阅读 的 标题 链接 至 详细 内 容 ， 管 理 员 单 击 “ 管 理 ” 
图 标 进 入 管理 页 面 。 系 统 主页 面 index. php 的 静态 页 面 设计 如 图 8-21 所 示 。 
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admin login php SKB PHP 
bbs add php 10KB PHP 
bbs reply. php SKb PHP 





content. php 11KB PHP 














del ref. php AKB PHP 
del reply. php SKB PH 
del title. php SKb PH 
index.php 9KB PHP 
wpd title. php 6KB PHP 


EET 


目前 没有 发表 任何 主 是 
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图 8-21 BBS 论坛 管理 系统 主页 面 静态 设计 效果 


详细 的 操作 步骤 如 下 。 
1) 单 击 “应 用 程序 ”面板 群 组 中 “ 绑 定 ” 面 板 上 的 四 按钮 ， 在 弹出 的 菜单 中 选择 
“记录 集 (查询 ) ”命令 ， 在 弹出 的 对 话 框 中 进行 如 下 设置 。 


e dt 
。 从 
。 从 
。 在 


“名 称 ” 文 本 框 中 输入 rs. bbs 作为 该 记录 和 集 的 名 称 。 

“连接 ”下 拉 列 表 框 中 ， 选 择 数 据 源 连接 对 象 bbs, 

“表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 bbs_main。 
“ 列 ” 栏 中 选择 “全 部 ” 单 选 按钮 。 


完成 的 设置 情况 如 图 8-22 所 示 。 
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图 8-22 设置 “记录 集 ” 对 话 框 


2) 再 单 击 “高 级 ”按钮 ， 进 入 记录 集 高 级 设 定 的 页 面 ， 将 现 有 的 SQL 语句 改 成 以 下 的 


SQL 语法 ， 


如 图 8-23 所 示 。 


EKE GCITXXLEED 
















| — mmists O 



































; ( m ) 
isi [us 司 ER 
(E 
SQL: SELECT bbs Main.bbs ID, bbs Main bbs Time, bbs Main. bbs, Xi ts, 
bbs Main. bbs Title, bbs Main bbs url, |ES 
bbs Main. bbs email, bbs Main. bbs sex, | sj 
bbs Main. bbs Face, bbs Main.bbs Content, bbs Main. bbs Name, COUNT 
(bbs Ref bbs Main ID) AS ReturnNum, MAK (bbs Ref.bbs ref Tine) AS — — 
zm s 
| 
| 数据 库 顺 [加 XH eI sa: 
hm mr 
s SELECT 
d. ”预存 过 程 
(mm |] 
ORDER BY 

















图 8-23 改写 SQL 语句 


01. SELECT 

02. bbs Main. bbs, ID, 

03. bbs Main. bbs Time, bbs, Main. bbs Hits 

04.^bbs Main. bbs, Title, bbs Main. bbs url, 
bbs Main. bbs, email, bbs Main. bbs, sex, 
bbs. Main. bbs Face, bbs, Main. bbs, Content, 

05. bbs, Main. bbs, Name, COUNT( bbs. Ref. bbs Main, ID) AS ReturnNum, 

06. MAX( bbs, Ref. bbs, ref Time) AS LatesTime 

07. FROM 

08. bbs Main LEFT OUTER JOIN bbs Ref ON 

09. bbs Main. bbs ID = bbs Ref. bbs Main ID 


10. GROUP BY bbs. Main. bbs ID 


TER UH] . 

第 一 条 bbs. ref 数据 表 中 的 记录 可 以 通过 bbs. main. ID 字段 关联 到 bbs. main 数据 表 中 的 
bbs ID 字段 。 因 为 bbs_ref 数据 表 中 对 应 的 数据 可 能 不 存在 ，bbs_main 数据 表 并 非 一 定 有 对 
应 回复 的 话题 ， 所 以 LEFT JOIN 将 接合 关系 中 的 两 个 数据 表 分 成 左右 两 个 数据 表 ， 其 中 左边 
数据 表 在 经 过 接合 后 ， 不 管 右边 数据 表 是 否 存 在 ,仍然 会 将 资料 全 部 列 出 。 简 单 地 说 ， 就 是 
不 管 讨 论 主题 bbs_main 是 否 有 任何 的 回复 bbs_ref， 都 可 以 使 用 LEFT JOIN 将 数据 表 bbs_ 
main 中 的 所 有 讨论 主题 显示 出 来 。 

另外 ，GROUP BY 语句 是 针对 bbs_main 数据 表 中 的 bbs_ID 字段 ,第 2 ~6 行 的 意思 是 取 
出 bbs_main 数据 表 中 的 特定 字段 内 容 。 同 时 将 bbs_ref 中 的 关联 字段 取出 ， 获 得 bbs_time 和 
bbs ID 的 两 个 字段 内 容 。bbs_ref_time 字段 取 所 有 记录 当中 时 间 最 新 回复 的 那 一 条 用 来 显 
示 。 而 bbs_ID 字段 则 用 COUNT 计算 有 多 少 人 回复 的 数目 。 

3) 绑 定 记录 集 后 ， 将 记录 集 的 字段 插入 至 index. php 网 页 中 的 适当 位 置 ， 如 图 8-24 所 示 。 
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图 8-24 字段 插入 至 index. php 

4) 捅 入 字段 后 ， 把 光标 放 和 到 “心情 ”下 面 的 单元 格 里 ， 然 后 再 执行 菜单 栏 “搬入 ” 

一 “图 像 ” 命 令 , 打开 “图 像 ” 对 话 框 任意 插入 一 张 图 片 ， 然 后 在 “属性 ”面板 中 设置 
Ser (W) 为 空 ， 如 图 8-25 所 示 。 单 击 “ 确 定 ” 按 钮 ,插入 一 个 图 像 占 位 符 。 


Et 
[gy 555 $c| = Omis x ~ RM20 [px | PAM PE 
2L Tu |— — joa 5E 2 &0020 [px -] 
wam | BRO | "| 
Do Berj — | 


图 8-25 图 像 “ 占 位 符 ” 对 话 框 
5) 在 置 Scr (W) 文本 框 中 设置 为 < ?php echo $row rs bbs[ bbs_Face ]; ? > ， 表 示 调 
用 动态 的 数据 值 ， 并 将 宽 和 高 的 值 清空 ， 如 图 8-26 所 示 。 
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8-26 ”选择 字段 


6) 单 击 “ 确 定 ”按钮 ， 完 成 记录 集 的 绑 定 。 接 下 来 进行 显示 区 域 的 设置 ， 首 先 ， 选 取 
记录 集 有 数据 时 要 显示 的 数据 表格 ， 如 图 8-27 所 示 。 


Eos 作 者 回复 最 新 回复 mi 发 布 时 间 








心情 x m 
prasnnnnnin na ne ni nn ni in nd 


5 irs bbs. bbs_Title} Hirs bbs. bbs Nane]tirs bbs. ReturnNon]trs bbs. LatesTime]t[rs bbs. bbs Mits]rirs bbs. iris] 


图 8-27 选择 要 显示 的 数据 表格 


7) 单 击 “ 服 务 右 行 为 ”面板 上 的 国 按 钮 ， 在 弹出 的 下 拉 菜 单 中 ,选择 “显示 区 域 ” 
一 “如 果 记 录 集 不 为 空 则 显示 区 域 ”选项 ， 在 打开 的 “如 果 记 录 集 不 为 空 则 显示 区 域 ”对 
话 框 中 ， 单 击 “ 确 定 ”按钮 回 到 编辑 页 面 ， 会 发 现 先 前 所 选取 要 显示 的 区 域 左上 角 出 现 了 
“如 果 符 合 此 条 件 则 显示 ”字样 ， 这 表示 已 经 完成 设置 ， 如 图 8-28 所 示 。 



































Dw zÐ dem(E) S&V EAD 修改 (M) 格式 (O) SAO 站 点 (S) SOW WAH) Ha. pun 
{ [X] ama  Q. m ES Jp] 








| T ins 2 
t - 3 ld 动态 文本 (rs bbs bbs Time) 


vig 1 





10096 (763) 
1396 (109) 


| dt aj] Eg 
| 














T 
[rss bbs None] (rs bbs. Returnllun] (rs bbs. LatesTine] [rs bbs. bbs, Hits] [rs bbs. bbs Tine] 






















































































图 8-28 完成 显示 设置 
8) 选择 没有 发 布 主题 数据 时 要 显示 的 文字 “目前 没有 发 表 任 何 主题 ”， 根 据 前 面 的 操 
作 方 法 ， 将 区 域 设 定 成 “如 果 记 录 集 为 空 则 显示 区 域 ” ， 如 图 8-29 所 示 。 
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图 8-29 选择 没有 数据 时 的 显示 


9) 加 入 “服务 器 行为 ”中 “重复 区 域 ”的 设置 ， 单 击 index. php 页 面 中 要 重复 的 记录 
列 ， 如 图 8-30 所 示 。 








图 8-30 选择 要 重复 显示 的 记录 列 


10) 单 击 “ 应 用 程序 ”面板 群 组 中 “服务 器 行为 ”面板 上 的 四 按 钮 ， 在 弹出 的 菜单 列 
表 中 ,选择 “重复 区 域 ”命令 ， 在 打开 的 “重复 区 域 ” 对 话 框 中 ， 设 置 显示 的 记录 数 为 
20， 如 图 8-31 所 示 。 

11) 单 击 “ 确 定 ” 按 钮 ， 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 重复 的 区 域 左 上 角 出 现 









QL*Dreamweaver 动态 爽 站 开发 人 入门 到 精通 


了 一 个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设置 。 

12) 单 击 “ 确 定 ”按钮 回 到 编辑 页 面 ， 当 记录 集 超 过 一 页 ， 就 必须 要 有 [上 一 页 ]、 
[下 一 页 ] 等 按钮 或 文字 ， 让 访问 者 可 以 实现 翻 页 的 功能 ， 这 就 是 “记录 和 集 导航 条 ”的 功 
能 。“ 记 录 集 导航 条 ”按钮 位 于 “插入 ”工具 栏 的 “数据 ”中 ， 因 此 将 “插入 ”工具 栏 由 
“常用 ”切换 成 “数据 ”类 型 ， 单 击 “记录 集 导 航 条 ”图 工 具 按钮 ， 如 图 8-32 所 示 。 
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fq, EHTA 
5g- 插入 记录 国 
图 8-31 选择 一 次 可 以 显示 的 记录 数 图 8-32 选择 “记录 集 导航 条 ” 


13) 在 打开 的 “记录 集 导 航 条 ”对 话 框 中 ， 选 取 要 导航 条 的 记录 集 并 设置 导航 条 的 显 
示 方 式 为 “文本 ”， 如 图 8-33a 所 示 ， 然 后 单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 会 发 现 页 面 出 
现 该 记录 和 集 的 导航 条 ， 如 图 8-33b 所 示 。 





记录 和 集 导 航 条 






































如 果 不 是 第 一 页 则 显示 (rs bbs) 
移 至 第 一 页 (rs_bbs) 
如 果 不 是 第 一 页 则 显示 (rs bbs) 
移 至 前 一 页 (rs bbs) 
如 果 不 是 最 后 一 页 则 显示 (rs bbs) 
移 至 下 一 页 (rs bbs) 
如 果 不 是 最 后 一 页 则 显示 (rs bbs) 
1 TE T P 移 至 最 后 一 页 rs_bbs) 
E | | | 如 果 记录 集 不 为 空 则 显示 (rs bb 
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b) 


图 8-33 添加 “记录 集 导 航 条 ” 
a) “记录 集 导航 条 ”对 话 框 _b) “记录 集 导航 条 ” 对 话 框 











14) 在 “讨论 主题 ”上 加 入 “ 转 到 详细 页 面 ”的 设置 ， 
用 来 显示 特定 主题 的 详细 内 容 及 相关 的 回复 。 选 取 编 辑 页 面 
中 的 rs bbs. bbs Title 字段 ， 如 图 8-34 所 示 。 

15) 在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 
“浏览 文件 ”图 标 ， 在 弹出 的 “选择 文件 ”对 话 框 中 选择 用 来 显示 详细 记录 信息 的 页 面 con- 
tent. php, 设置 如 图 8-35 所 示 。 





图 8-34 ”选择 字段 
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图 8-35 选择 链接 文件 


16) 单 击 “ 人 参数 ”按钮 ， 设 置 超级 链接 要 附带 的 URL 参数 的 名 称 与 值 content. php? bbs 
_id =<? php echo $row_rs_bbsf bbs ID ]; ? > 。 将 参数 名 称 命名 为 bbs_id， 如 图 8-36 所 示 。 
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图 8-36 “动态 数据 ”属性 设置 

















17) 完成 “ 转 到 详细 页 面 ”的 设置 ， 在 index. php 页 面 中 有 两 个 链接 图 示 “ 管 理 ” 与 
“发 表 话 题 ”， 必 须 设 定 其 链接 网 页 ， 如 表 8-6 所 示 。 
表 8-6 按钮 链接 的 页 面 表 








按钮 名 称 链接 页 面 
管理 admin_login. php 
发 表 话 题 bbs_add. php 





uu 搜索 主题 功能 制作 


在 index. php 这 个 页 面 上 加 入 搜索 的 功能 ， 该 页 面 上 的 功能 设计 如 图 8-37 所 示 。 











制作 步骤 如 下 。 


1) 将 查询 主题 的 文本 域 命名 为 keyword。 设 置 如 图 8-38 所 示 。 
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8-37 ”搜索 主题 设计 
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图 8-38 设置 keyword 文本 域名 





动态 网 站 开发 从 入 门 到 精通 








类 CC) 





2) 将 之 前 建立 的 记录 集 rs bbs 做 一 些 更 改 ， 打 开 记 录 集 ， 并 进入 “高 级 ” 设 定 对 话 
框 。 在 原 有 的 SQL 语句 中 GROUP BY bbs. Main. bbs ID 前 面 ， 加 入 一 段 查询 功能 的 语句 ; 


WHERE bbs, Title liké 96". 


SQL 语句 将 变 成 如 图 8-39 所 示 。 


Skeyword. " 96 

































































记录 和 集 
> == 
dp rs_bbs | 
连接 : |bbs | [EX = 
SQL: LatesTime 
FROM bbs Main LEFT OUTER JOIN bbs Ref ON 
bbs Main bbs ID-bbs Ref.bbs Main ID E 
RE bbs Title like ` 8“. $keyword. "8% [8] 
GROUP BY bbs Main bbs ID z 
| 变量 : 
D E EZ 
数据 库 项 : E ”表格 添加 到 SQL: 
Aa 视图 
d. ”预存 过 各 xum 
WHERE 
ORDER BY 














图 8-39 


修改 SQL 语句 












3) 再 切换 到 代码 设计 窗口 。 在 rs. bbs 记录 集 绑 定 的 代码 中 加 入 代码 ; 
$keyword = $_POST[ keyword] ; //3E X. keyword 为 表单 中 "keyword" 的 请 求 变 量 


如 图 8-40 所 示 ， 完 成 设置 。 
4) 以 上 的 设置 完成 后 ， 系 统 主页 面 index. php 就 有 查询 功能 了 ， 可 以 按 下 《Fl12》 键 至 


浏览 


如 图 8-41 所 示 。 














， 测 试 一 下 是 否 能 正确 地 查询 并 显示 。index. php 页 面 会 显示 所 有 网 站 中 的 讨论 主题 ， 
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TÈ cxampp\htdocs\bbs\index.php EXE 
LIZED bbs. php m 
n 1 <?php require once('Connections/bbs.php'); ?> ^ 
2| 2 <?php E 
* E TO a | 
e| 4 if (1!function exists("GetSQLValueString")) { 
" 5 function GetSQLValueString($theValue, $theType, $theDefinedValue = "", $theNotDefinedValue = 
2$ nu 
ai ) 
est 
EM 7 if (PHP VERSION < 6) { 
*€* a $theValue = get magic quotes gpc() ? stripslashes($theValue) : $theValue; 
IU o } 
10 
11 $theValue = function exists("mysql real escape string") ? mysql real escape string( 


$theValue) : mysql escape string($theValue); 


switch (StheType) 1 
case "text": 
$theValue = ($theValue !- "") ? "'" , S$StheValue . "'" : 
break; 
case "long": 
case "int": 
$theValue = ($theValue !- "") 2 intval($theValue) : "NULL"; 


"NULL"; 











8-40 加 入 代码 
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图 8-41 





主页 面 讨论 主题 的 浏览 效果 


访问 者 页 面 的 设计 


供 论坛 访问 者 使 用 的 页 面 有 讨论 主题 内 容 页 面 content. php 和 回复 讨论 页 面 bbs_re- 
ply. php。 下 面 就 开始 这 两 个 页 面 的 制作 。 


"讨论 主题 内 容 页 面 


讨论 主题 内 容 页 面 content. php 是 实现 讨论 主题 的 详细 内 容 页 面 。 这 个 页 面 会 显示 讨论 
主题 的 详细 内 容 与 所 有 回复 者 的 回复 内 容 ， 其 静态 页 面 设计 如 图 8-42 所 示 。 

















个 记录 集 进行 合并 ， 
参数 bbs ID 进行 筛选 。 
2) 单 击 “应 用 程序 ”面板 群 组 中 “ 绑 定 ”面板 上 的 时 按钮 ， 在 弹出 的 菜单 中 ， 选 择 
po AD uu pa a 进入 记录 和 集 高 
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图 8-42 讨论 主题 内 容 页 面 设计 效果 


详细 的 操作 步 又 如 下 。 





1) 在 content. php 这 个 页 面 中 ， 要 同时 显示 讨论 主题 与 回复 主题 的 内 容 ， 
这 两 个 数据 表 中 的 所 有 字段 ， 


一 次 取得 


根据 主题 页 面 传送 


设 定 的 对 话 框 ， 将 现 有 的 SQL 语句 改 成 如 下 的 SQL 语句 ， 如 图 8-43 所 示 。 

















(mm -—— ^-^ 4 
名 称 : detail a ME 
SAM zx 取消 

il 连接 : |bbs x| 













mis 





| SQL: SELECT bbs main 机 bbs ref. 

FROM bbs main LEFT OUTER JOIN bbs ref ON 
bbs main bbs_ID=bbs_ref. bbs main ID 

I WHERE bbs main.bbs ID =' ".$bbs ID. 
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添加 到 SQL: 








SELECT 


(mm |] 




















图 8-43 


ORDER BY 








改写 SQL 语句 


因此 需要 把 两 
过 来 的 URL 











BBS 论坛 管理 系统 





01. SELECT 

02. bbs main. * ,bbs ref. * 

03. FROM 

04. bbs main LEFT OUTER JOIN bbs. ref ON bbs main. bbs. ID = 
bbs, ref. bbs, main, ID 

05 WHERE bbs main. bbs ID +". $bbs ID. " 





重点 说 明 : 同样 用 LEFT OUTER JOIN 关联 bbs_main fe bbs ref 中 的 字段 ， 取 得 两 个 数据 
表 中 的 相关 数据 。 并且 用 WHERE 语句 ， 筛 选 bbs_main 数据 表 中 的 bbs ID 字段 值 等 于 $bbs 
_ID 变量 值 。 
3) 上 图 中 设置 了 一 个 名 为 $bbs_ID 的 变量 值 ， 即 是 首页 传递 过 来 的 参数 ， 因 此 在 该 页 
自动 生成 的 PHP 代码 中 的 第 一 行 加 入 如 下 的 变量 赋值 。 
$bbs_ID = strval( $_GET{ bbs id ] ) ; 


4) 在 设 定 记录 集 绑 定 后 ， 先 把 记录 集 detail 中 的 字段 插入 到 页 面 上 ， 再 分 别 插入 两 个 
图 像 占 位 符 ， 两 个 图 像 占 位 符 分 别 绑 定 发 布 人 性 别 形象 bbs_sex 字段 和 回复 人 性 别 形象 bbs_ 
ref sex 字段 ， 其 结果 如 图 8-44 所 示 。 
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L^ 庄 题 内 容 : (detailbbs content) 


发 表 人 : {detailbbs_name} 





S 电子 邮件 ox Gasta 


E 回复 内 容 : (detailbbs ref content] 


回复 人 : (detailbbs ref name] 





























ED {detailbbs ref time) È EFA © 主页 





Copyright @ 2011 www.hbculture.com Inc.All rights 











body> [R] Q [00% v845 x 581v 72 K / 2% Unicode (UTF-8) 








图 8-44 detail 中 的 字段 插入 


5) 单 击 选择 主题 表格 中 的 文字 “电子 邮件 ”， 然 后 单 击 “ 属 性 ”面板 中 的 “链接 ” 文 
本 框 后 面 的 “浏览 文件 ”按钮 回 ， 打 开 “ 选 择 文件 ”对 话 框 ， 在 该 对 话 框 中 选择 “数据 
源 ” 单 选 按钮 ， 然 后 在 “ 域 ” 列 表 框 中 ,选择 “记录 集 (detail) ”中 的 bbs email 字段 ， 并 
HE URL 链接 前 面 加 上 “mailto:”， 如 图 8-45 所 示 。 
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图 8-45 设置 主题 栏 中 的 email 的 链接 


6) 单 击 选择 主题 表格 中 的 文字 “主页 ”， 单 击 “ 属 性 ”面板 中 “链接 ”文本 框 后 面 的 
“浏览 文件 ”按钮 回 ， 打 开 “ 选 择 文件 ”对 话 框 ， 在 该 对 话 框 中 选择 “数据 源 ” 单 选 按钮 ， 
然后 在 “ 域 ” 列 表 框 中 ,选择 “记录 集 (detail)” 中 的 bbs_url 字段 ， 并 且 在 URL 链接 前 面 
加 上 http;//, "HK 8-46 所 示 。 
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图 8-46 设置 主题 栏 中 的 ul 链接 


7) 用 第 5、6 步骤 中 的 方法 ， 设 置 回 复 主题 中 的 “电子 邮件 ”和 “主页 ”的 链接 。 一 
个 是 “记录 集 (detail) ”中 的 bbs_ref_email 字段 ， 另 一 个 是 “记录 集 (detail) ”中 的 bbs_ 
ref ud 字段 ， 如 图 8-47 和 图 8-48 所 示 。 
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图 8-47 设置 回复 栏 中 的 email 的 链接 
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图 8-48 设置 回复 栏 中 的 url 链接 





8) 单 击 “确定 ”按钮 ， 完 成 数据 源 的 绑 定 设置 ， 在 content php 页 面 中 有 两 个 链接 图 
示 “ 管 理 ” 与 “发 表 话题 ”， 必 须 设 定 其 链接 网 页 ， 如 表 8-7 所 示 。 


表 8-7 按钮 与 链接 页 面 表 








按钮 名 称 链接 页 面 
管理 admin_login. php 
发 表 话 题 bbs_add. php 





9) 选择 文字 “回复 主题 ”, 在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 “浏览 文 
件 ” 图 标 ， 在 弹出 的 对 话 框 中 选择 用 来 显示 详细 记录 信息 的 页 面 content. php， 设 置 如 





BBS 论坛 管理 系统 





图 8-49 所 示 。 
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8-49 选择 链接 文件 
10) 单 击 “ 参 数 ” 按 钮 ， 设 置 超级 链接 要 附带 的 URL 参数 的 名 称 与 值 bbs_reply. php? 
bbs ID =< ?php echoS$row, detail[ bbs ID ] ; ? > 。 将 参数 名 称 命名 为 bbs_ID， 设置 如 图 8-50 
所 示 。 
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图 8-50 “动态 数据 ” 对 话 村 


Ir 





11) 加 入 “服务 器 行为 ”中 “重复 区 域 ” 的 设 定 ， 单 击 content. php 页 面 中 要 重复 的 表 
格 ， 如 图 8-51 所 示 。 


回复 人 : (detailbbs ref name) 回复 内 容 : (detailbbs ref content) 


UD fastailbbs ref time) S 电子 邮件 O 主页 





图 8-51 选择 要 重复 的 表格 


12) 单 击 “应 用 程序 ”面板 群 组 中 “服务 器 行为 ”面板 上 的 内 按钮 ， 在 弹出 的 菜单 
中 ,选择 “重复 区 域 ”命令 ,在 打开 “重复 区 域 ” 对 话 框 中 ， 设 置 显示 的 记录 数 为 5 条 ， 
如 图 8-52 所 示 。 单 击 “ 确 定 ”按钮 ， 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 重复 的 区 域 左上 
角 出 现 了 一 个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设置 。 

13) 插入 “记录 集 导航 条 ”功能 ， 单 击 到 工具 按钮 ， 在 打开 的 “记录 集 导 航 条 ”对 话 
框 中 ， 选 取 要 导航 条 的 记录 集 以 及 导航 条 的 显示 方式 ， 然 后 单 击 “ 确 定 ”按钮 回 到 编辑 页 
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动态 网 站 开发 从 入 门 到 精通 | 





(sm | 


记录 集 : detail X 


显示 : 回 5 记录 








所 有 记录 








网 8-52 选择 一 次 可 以 显示 的 记录 数 





面 ， 会 发 现 页 面 出 现 了 该 记录 集 的 导航 条 ， 如 图 8-53 所 示 。 


* C: MpachelhtdocsVbbsVcontent. php -Dnx 


Ehe bbs php 








y esmertm vm 
OA IPT 


讨论 主题 : (detail bbs — 


主题 内 容 : (detailbbs content) 
发 表 人 : (detallbbs name] 


G 电子 邮件 O 主页 Casts 


回复 内 容 : (detailbbs ref content) 


回复 人 : (detailbbs ref name} 





CD {detailbbs ref time) S EFA © 主页 








Copyright @ 2011 www .hbculture.com Inc.All rights reserved. 论坛 之 家 


body? (table? Ctr? «td Ktable?] [X 8) qQ 100€  v|84T x 522v TT K / 2 EP Unicode QUTF-B) .: 
图 8-53 添加 “记录 集 导航 条 ” 








14) 选取 记录 集 有 数据 时 要 显示 的 数据 表格 ， 如 图 8-54 所 示 。 
E 


回复 人 : {detailbbs_ref name) | 回复 内 容 : {detailbbs_ref_content} 








LÒ (detalbhs ref time} S EFM O 主页 


图 8-54 选择 要 显示 的 数据 表格 


15) 单 击 “服务 器 行为 ”面板 上 的 加 按钮 ， 在 弹出 的 菜单 中 选择 “显示 区 域 ”一 “如 
果 记 录 集 不 为 空 则 显示 区 域 ”命令 ， 在 打开 的 “如 果 记 录 集 不 为 空 则 显示 区 域 ”对 话 框 中 ， 
选择 “记录 集 ” 下 拉 列 表 框 中 的 “detail” 选 项 ， 单 击 “确定 ”按钮 回 到 编辑 页 面 ， 会 发 现 





















回复 人 : (detailbbs ref name) 回复 内 容 : (detaillbbs ref content) 


ED (detallios mf time) S EFA © 主页 


图 8-55 完成 设置 后 的 效果 


16) 选择 没有 回复 数据 时 要 显示 的 文字 “目前 没有 回复 ”， 根 据 前 面 的 步 又， 将 下 面 区 
域 设 定 成 “如 果 记 录 集 为 空 则 显示 区 域 "， 如 图 8-56 所 示 。 















回复 人 : 回复 内 容 : (detailbbs ref content] 
(detailbbs ref name) 





UP qdetalbbs ref time) S 电 子 邮件 © 主页 
如 果 符 合 此 条 件 则 显示 .. . 
[n] E3 








图 8-56 选择 没有 数据 时 的 显示 


8.4.2 设置 点 击 次 数 


在 BBS 论坛 系统 主页 面 中 设置 了 文章 阅读 统计 功能 ， 当 访问 者 点 击 标题 进入 查看 内 容 
时 ， 阅 读 统计 数目 就 要 增加 一 次 。 其 主要 的 方法 是 更 新 数据 表 bbs_main 里 的 bbs hits 字段 来 
实现 。 

详细 操作 步骤 如 下 。 

1) 实现 的 方法 很 简单 ， 打 开 content. php 页 面 ， 在 代码 的 第 50 行 加 入 一 行 更 新 的 SQL 
语句 : mysql query( " UPDATE bbs, main SET bbs. hits = bbs. hits +1 WHERE bbs ID + ". $bbs_ 
ID. " "); 





代码 说 明 如 下 : 
01. UPDATE bbs_main // 更 新 bbs. main 数据 表 
02. SET bbs hits = bbs hits + 1 // 设 置 bbs, main 数据 表 中 的 bbs. hits 中 字段 自动 加 1 


03. WHERE bbs ID + ". $bbs ID. " — // bbs ID 的 值 等 我 bbs_ID 变量 中 的 值 





2) 加 入 的 代码 位 置 如 图 8-57 所 示 。 





e 








动态 网 站 








El cxampp\htdocs\bbs\content.php = 口 X 
(dio bbs. php 

40 $pageNum_detail = $_GET['pageNum_detail']; A 
B 41 
* 42  $startRow detail = $pageNum detail * $maxRows detail; 

43 
zt 
**| 44 mysql select db($database bbs, $bbs); [3 
ES] 45 $query detail = "SELECT bbs main.*,bbs ref.* FROM bbs main LEFT OUTER JOIN bbs ref ON E 
z bbs main.bbs ID-bbs ref.bbs main ID WHERE bbs main.bbs ID -'".$bbs ID."' "; 


46  $query limit detail = sprintf("*s LIMIT %d, 96d", $query detail, $startRow detail, $maxRows, detail); 
$detail - mysql query($query limit detail, $bbs) or die(mysql error()); 
$row detail - mysql fetch assoc($detail); 


UP 

ex 
BR 
oA 


.query("UPDATE bbs main SET bbs hits = bbs hits + 1 WHERE bbs ID = '".$bbs ID."'"); 





55 $totalRows detail - $ GET['totalRows detail']; 
56 else { 

57 $all detail = mysql query($query detail); 

58 $totalRows detail - mysql num rows($all detail); 


60 $totalPages detail = ceil($totalRows detail/$maxRows detail)-1; 








DE 
加 54 if (isset($ GET['totalRows detail'])) { 
Q 
v 
a, 
B 
Y 























图 8-57 代码 加 入 的 位 置 





新 增 讨 论 主题 页 面 bbs_add. php 的 功能 是 将 页 面 的 表单 数据 新 增 到 站 点 的 bbs_main 数 
据 表 中 ， 页 面 设 计 如 图 8-58 所 示 。 
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图 8-58 新 增 讨 论 主题 页 面 效果 


详细 操作 步骤 如 下 。 
1) f£ bbs add. php 页 面 设 计 中 ， 表 单 forml 中 的 文本 域 和 文本 区 域 设置 如 表 8-8 所 示 。 
这 里 要 注意 性 别 形象 和 心情 的 单 选 按 钮 都 要 在 属性 面板 中 定义 其 值 。 














第 8 言 CNAA 


表 8-8 RË formi 中 的 文本 域 和 文本 区 域 设 置 方 法 表 

































































意 X 文本 (区 ) 域 /按钮 名 称 方法 /类 型 
表单 forml POST 
新 主题 bbs title 单行 
发 表 人 bbs_name 单行 
性 别 形 象 bbs_sex 单 选 按钮 
心情 bbs_face 单 选 按钮 
电子 邮件 bbs_email 单行 
个 人 主页 bbs_url 单行 
主题 内 容 bbs_content 多 行 
提交 的 时 间 bbs_time 了 r À 
阅读 次 数 bbs_hits 初始 值 为 0 
确定 提交 Submitl 提交 表单 
重新 填写 Submit? 重 设 表单 








2) 在 bbs add. php 编辑 页 面 ， 单 击 “ 服 务 器 行为 ”面板 上 的 办 按钮 ， 在 弹出 的 荣 单 
中 ,选择 “插入 记录 ”命令 ,在 “插入 记录 ”的 对 话 框 设置 如 下 。 
e 从 “连接 ”下 拉 列 表 框 中 选择 bbs 作为 数据 源 连接 对 象 。 
e 从 “插入 表格 ”下 拉 列 表 框 中 选择 bbs_main 作为 使 用 的 数据 库 表 对 象 。 
。 在 “搬入 后 ， 转 到 ”文本 框 中 设置 记录 成 功 添 加 到 表 bbs_main， 然 后 再 转 到 in- 
dex. php 网 页 。 
。 在 “ 列 ” 的 列 选 对 话 框 中 ， 将 网 页 中 的 表单 对 象 和 数据 库 中 表 bbs_main 中 的 字段 一 























































一 对 应 起 来 o 
Iu ~ cb E Y -— 
设置 完成 后 该 对 话 框 如 图 8-59 所 示 。 
EE z | 
提交 值 ， 自 : |fornl -] 确定 
连接 : [bs x] 取消 
插入 表格 : |bbs_main Mi 帮助 
列 : bbs_ID” 是 一 个 未 使 用 的 主键 。 
"bbs title' M, “FORM. bbs_title’ 
` bb t M 'FORM. tent" 
FORM. bbs : 
s email! JA 'FORM.bbs emai 
人 o] 
mse 
| 插入 后 ， 转 到 : index. php | 3... 
一 -一 一 | 

















图 8-59 设 定 “ 插 入 记录 ” 


3) 选择 表单 执行 菜单 栏 上 “窗口 ”一 “行为” 命令， 打开“ 行为 ”面板 ， 单 击 “ 行 
为 ”面板 中 的 因 按 钮 ， 在 弹出 的 菜单 中 ， 选 择 “检查 表单 ”命令 ， 打 开 “ 检 查 表单 ”对 话 
框 ， 设置 “ 值 ” 和 “可 接受 ”范围 。 如 文本 bbs_email“ 值 ”设置 为 “必需 的 ",“ 可 接受 " 








为 “电子 邮件 地 址 ”， 如 图 8-60 所 示 。 


o O9 o 。 


动态 网 站 开发 从 入 门 到 精通 | 








EZ Pisis. 











input "bbs : title" R) 


input "bbs ; name” "- 
t 
1" (9) 


input "bbs ur 




















: M 必需 的 





: O 任何 东西 O 数字 
© 电子 邮件 地 址 O 数字 从 





图 8-60 “检查 表单 ”对 话 框 


Hi 























4) 单 击 “确定 ”按钮 ， 回 到 编辑 页 面 ， 完 成 bbs_add. php 页 面 插 和 人 记录 的 设置 。 
5) 按 下 〈(F12〉 键 至 浏览 器 测试 一 下 。 首 先 打开 bbs add. php 页 面 再 填写 表单 ， 填 写 


表单 资料 如 图 8-61 所 示 。 





E 360 安 全 浏览 器 7.1 





€ CC € ú Y http//127.00.1/bbs/bbs add.php 





p O| Ersta x |+ 





RRA: |test 
性 别 形象 : 


心情 : e 3o 
电子 邮件 : |test@163 com 
个 人 主页 : [wen test c com 
主题 内 容 : | testi 












































图 8-61 填写 表单 资料 


6) 填写 资料 完成 以 后 ， 单 击 “ 确 定 提交 ”按钮 ， 将 此 资料 发 送 到 bbs main 数据 表 
中 。 页 面 将 返回 到 BBS 讨论 系统 主页 面 index. php， 如 图 8-62 所 示 ， 表 示 发 布 新 主题 


成 功 。 
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图 8-62 


发 表 新 主题 成 功 


um 回复 讨论 主题 


回复 讨论 主题 页 面 bbs_reply. php 的 设计 与 讨论 主题 内 容 页 面 的 制作 相似 ， 回 复 
将 表单 中 填写 的 数据 插入 到 bbs vef 数据 表 中 ， 页 面 设计 效果 如 图 8-63 所 示 。 
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图 8-63 


回复 讨论 主题 页 面 设计 效果 


1) 由 于 在 讨论 主题 内 容 页 面 content. php 中 ， 设 定 有 传递 参数 bbs. ID. (主题 编号 ) 会 
传递 到 这 一 页 面 ， 因 此 必须 先 将 这 个 参数 绑 定 到 一 个 命名 为 bbs_main_ID 的 隐藏 域 中 。 在 页 
面 上 搬入 以 下 隐藏 域 ， 并 命名 为 bbs_main_ID ， 并 定义 其 值 为 















uw ww ow w 9 





QL*Dreamweaver 动态 网 站 开发 
« ?php echo$bbs main ID ?> 


如 图 8-64 所 示 。 


属性 


| IN] [I ean 
bbs main ID V) php echo $bbs main ID ?> 多 











ED 























图 8-64 设置 隐藏 域 bbs_main_ID 的 值 
2) 然后 再 单 击 | 代码 _ 按钮， 切换 到 代码 窗口 ， 将 如 下 的 代码 加 入 到 第 1 £7: 




















< ?php 
$bbs_main_ID = strval($_GET[ bbs ID ]); 
7» 
如 图 8-65 所 示 。 
Dw 。 文 #(。 %86 S&V EAD 修改 (M) 格式 (0) AO 站 点 (5) SOW 帮助 (H) HA. i SERRE 


















i - s ^| ASE Gnput.value, Crhpiat.. 
EA H 动态 文本 域 bs main D) 


«html xmlns-"http://www.w3.0rg/1999/xhtml"» 
5 «head» 

6 <meta http-equiv-"Content-Type" content-"text/html; charset-utf-8" /> 
7 ”<title> 论 坛 管理 系统 </title> 


B <style type="text/css"> 


Apu | o [s 


19 body { 










d 
u margin-top: 6px; 
CE 
13 body,td,th { 
14 font-family: 宋体 ; 
15 font-size: 12px; 
16 ) 


17 .stylel8 (color: #FFFF00} 
18  .style25 (font-size: l8px; font-weight: bold; 
19 a:link f 





I 8 fes] ce (r1) 









<? "sums 


$bbs nain ID-strval($ GET[' bbs ID']); 

















图 8-65 加 入 代码 


3) 再 插入 一 个 隐藏 字段 bbs ref _timne， 绑 定 为 当时 的 时 间 。 


< ?php 
date default timezone set( Asia/Shanghai ) ; 
echo date(" Y -m - d") ; 


?> 
属性 面板 的 设置 如 图 8-66 所 示 。 
属性 











区 FD btt 
bbs ref time 1B (V) V?phpdate default timezone set( | 47 


Rd 























图 8-66 设置 隐藏 区 域 值 








从 入 门 到 精通 


BBS 论坛 管理 系统 





4) 在 bbs reply. 


php 编辑 页 面 ， 单 击 “应 用 程序 ”面板 群 组 中 “服务 器 行为 ”面板 中 


的 由 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 捕 入 记录 ”命令 ， 在 “搬入 记录 ”的 设 定 对 话 框 中 设 


置 如 下 。 


e 从 “连接 ”下 拉 列 表 框 中 选择 bbs 作为 数据 源 连 接 对 象 


e 从 “插入 表格 ”下 拉 列 表 框 中 选择 bbs. ref 作为 使 用 的 数据 库 表 对 象 


转 到 ”文本 框 中 设置 记录 成 功 添加 到 表 bbs_ref， 然 后 再 转 到 index. php 

















































































e 在 “插入 后 ， 
网 页 。 
e 在 “ 列 ”的 选项 中 ， 将 网 页 中 的 表单 对 象 和 数据 库 中 表 bbs_ref 中 的 字段 一 一 对 应 
起 来 。 
设置 完成 后 ， 该 对 话 框 如 图 8-67 所 示 。 
EE P = 
| aE erc [en -] 
| 连接 : [bbs -] 取消 
| 插入 表格 : bbs ref =] | AB | 
»rr eu E TER bbs asin pI qiiid Eey 
Lus GE 
t is SOREA XA 
wr FORI. bb ful " GR 
T ref ail' JA ’ FORM. bbs ref email! EEIE XU. 
omm 
提交 为 : [文本 Š 
插入 后 ， 转 到 : index. php | BE 

















5) 选择 表单 执 和 








出 





图 8-67 设置 “插入 记录 ”对 话 框 
菜单 “窗口 ”一 “行为 ”命令 ， 打开 “行为 ”面板 ， 单 击 “ 行 为 ” 


面板 中 的 由 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “检查 表单 ”命令 。 打 开 “ 检 查 表单 ”对 话 框 ， 


设置 文本 域 的 “ 值 ” 


为 “必需 的 "，“ 可 接受 ”为 “任何 东西 "， 其 中 bbs ref email 字段 为 


“电子 邮件 地 址 ”， 如 图 8-68 所 示 。 





m9 
一 
he 
input “bbs re uia (RisEmail) 










































iB: [V] 必需 的 





l az: © 任何 东西 O ger 
© 电子 邮件 地 址 O 数字 从 到 




















Ir 


图 8-68 设置 “检查 表单 ”对 话 村 





6) 单 击 “ 确 定 ” 按 钮 ， 回 到 编辑 页 面 ， 这 样 就 完成 了 bbs reply. php 页 面 插 和 人 记录 的 


设计 。 


7) 按 下 《Fl12》 键 至 浏览 器 测试 。 首 先 打开 首页 面 ， 选 择 其 中 任意 一 个 讨论 主题 ， 进 








人 content. php WH, TE content. php 页 面 单 击 “ 回 复 主 题 ”， 转 到 回复 讨论 主题 bbs_re- 





ply. php 页 面 ， 在 bbs_reply. php 页 面 填 写 表 单 ， 填 写 表单 资料 如 图 8-69 所 示 。 





E 360 安 全 浏览 器 7.1 














。 ”PHP 论坛 管理 系统 





BEA: [aamin 





| 电子 邮件 : [admin@163 com 
个 人 主页 : || 
HEBES 














[ec ft * | http//127.0.0.1/b bs/bb s re ply.php?bbs ID-2 o 
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8-69 


填写 表单 资料 


8) 填写 资料 完成 以 后 ， 单 击 “ 确 定 提 交 ” 按 钮 ， 将 此 资料 发 送 到 bbs ref 数据 表 中 。 
页 面 将 返回 到 BBS 讨论 区 系统 内 容 页 面 index. php， 再 单 击 主题 后 可 以 看 到 回复 ， 如 图 8-70 


所 示 ， 表 示 回 复 主题 成 功 。 





尼 360 安 全 浏览 器 7.1 





>| O| Bws 





主题 内 容 : 这 是 测试 用 的 ， 再 试 





(© 2011-0807 S 电子 邮件 C 


3 
PHP 论 坛 管理 系统 C 


主页 


« -a|w|—imi| x 






SH XA 


回复 内 容 : 这 是 测试 回复 的 


B * lv 














图 8-70 








回复 主题 成 功 


BBS 论坛 管理 系统 





HS mnes 


BBS 论坛 管理 系统 的 后 台 管 理 比较 重要 ， 访 问 者 在 回复 主题 时 回复 一 些 非法 或 者 不 文明 
的 信息 时 ， 管 理 员 可 以 通过 后 台 对 非法 或 不 文明 的 信息 进行 删除 。 


MES 后 台 管 理 登 录 


由 于 管理 页 面 是 不 允许 网 站 访问 者 进入 的 ， 必 须 受 到 权限 管理 ， 可 以 利用 管理 员 账 号 和 
管理 密码 来 判别 是 否 有 此 用 户 ， 设 计 如 图 8-71 所 示 。 
Dw BR. © -io x 


XHA SRE EEV EAD 修改 (M) E ies) EE) ENG feug 
sdminiogiphp" x bs - Campp\htdocs 











































;| 车 要 在 该 页 面 上 使 用 动态 数据 : 
:iv 1 请 为 该 文件 创建 一 个 站 点 。 








4 a ) 按 并 渤 反 记录 
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图 8-71 “BBS 后 台 管理 登录 页 面 ”设计 

其 详细 操作 步骤 如 下 。 

1) 打开 后 台 管 理 登录 页 面 admin login. php， 单 击 “应 用 程序 ”面板 群 组 中 “服务 器 行 
为 ”面板 上 的 四 按钮 ， 在 弹出 的 菜单 中 选择 “用 户 身 份 验证 /登录 用 户 ” 的 命令 ， 在 打开 
“登录 用 户 ” 对 话 框 中 ， 设 置 为 如 果 不 成 功 将 返回 BBS 论坛 系统 主页 面 index. php, WR 
功 将 转向 后 台 管 理 管理 页 面 admin. php， 设 置 如 图 8-72 所 示 。 


从 表单 区 了 输入 [Earl 




















- 
- 
- 
- 
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| |password 
admin. php 3»... 

T 转 到 前 一 个 URLG0 果 它 存在 

如 果 登 录 失 败 ， 转 到 : index. php ET 
































基于 以 下 项 限制 访问 : @ 用 户 名 和 密码 
O REPRE 
RRRA: 10 | 





Ir 





图 8-72 WE “RHP” oisi 









PHP-MySQL*Dreamweaver 动态 两 站 开发 从 入 门 到 精通 





2) 选择 表单 ， 执 行 菜单 “窗口 ”一 “行为 ”命令 ， 打 开 “ 行 为 ”面板 ， 单 击 “ 行 为 ” 
面板 中 的 由 按钮 ， 在 弹出 的 荣 单 中 ， 选 择 “检查 表单 ”命令 ， 打 开 “ 检 查 表单 ”对 话 框 ， 


设置 username 和 password 文本 域 的 “ 值 ” 都 为 “必需 的 ”, “可 接受 ”为 “任何 东西 ”>， 如 
图 8-73 所 示 。 















































: © 任何 东西 © 数字 
O 电子 邮件 地 址 O 数字 从 











图 8-73 设置 “检查 表单 ”对 话 框 


Hi 





3) 单 击 “ 确 定 ”按钮 ， 回 到 编辑 页 面 ， 现 在 后 台 管 理 登 录 页 面 admin. login. php 的 设 
计 与 制作 都 已 经 完成 ， 如 图 8-74 所 示 。 








&B CAxampphtdocsVbbsyadmin login.php XX 
bbs. php Y 
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[R7>> body B E EH 55 x 121» 











图 8-74 设置 完毕 的 版 主 登 录 页 面 





GG 后 台 版 主管 理 


BBS 论坛 管理 系统 的 后 台 版 主管 理 页 面 是 版 主 由 登录 的 页 面 验证 成 功 后 所 转 到 的 页 面 。 
这 个 页 面 主 要 为 版 主 提供 对 数据 的 新 增 、 人 修改、 删除 内 容 等 功能 。 后 台 版 主管 理 页 面 ad- 
min. php 的 内 容 设计 与 BBS 论坛 系统 主页 面 index. php 大 致 相同 ， 不 同 的 是 加 入 可 以 转 到 所 
编辑 页 面 的 链接 。 页 面 效 果 如 图 8-75 所 示 。 

1) 后 台 版 主管 理 页 面 admin. php 中 ， 动 态 显示 部 分 和 index. php 是 一 样 的 ， 所 以 可 以 
直接 将 index. php 保存 为 admin. php 页 面 ， 然 后 再 加 入 “修改 ”和 “删除 ”的 两 列表 格 。 
个 讨论 主题 后 面 都 各 有 一 个 “修改 ”按钮 和 “删除 ”按钮 ， 它 们 分 别 是 用 来 修改 和 删除 某 
个 讨论 主题 的 ， 但 不 是 在 这 个 页 面 执行 ， 而 是 利用 转 到 详细 页 面 的 方式 ， 另 外 打开 一 个 页 面 
进行 相应 的 操作 。 






































































































































































































Dw 文件 %86 SEV AD 修改 (M) ”格式 (D) 命令 (C) ”站 点 (S) SOW WHH) HA. (cun x 
| Bde [E] me Q md 论坛 之 家 对 | 
E x (Etts | [本 地 视图 z] 
ESD M lejel*tswselm 
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4 = adnin php 108 D 
| =, admin login. php 5KB PHP 
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=, content. php 11KB PHP 
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2d T del_reply. php SKB PHP 
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Copyright @ 2011 wwmr.hbculture.com Inc.All rights reserved. 论坛 之 家 
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Bs css ma) X 
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后 台 版 主管 理 页面 的 设计 效果 





图 8-75 


2) 单 击 admin. php 页 面 中 的 “删除 ”按钮 ， 在 “属性 ”面板 中 设置 “链接 ”如 
图 8-76 所 示 : 


del title. php?bbs ID =< ?php echo$row rs bbs[ bbs ID ]; ?> 
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图 8-76 ”设置 “链接 ”属性 


3) 单 击 admin. php 页 面 中 的 “修改 ”按钮 ， 在 “属性 ”面板 中 设置 “链接 ”如 


图 8-77 所 示 : 
































upd title. php?bbs ID =< ?php echo$row rs bbs[ bbs ID ]; ?> 















































































































































属性 
H Elf, 1K JE 16 WMI (E) inages/write.gif & Oo 替换 CDD v 类 (0) x 
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图 8-77 设置 “链接 ”属性 



































4) 由 于 讨论 区 的 管理 权限 是 属于 版 主 的 ， 因 此 必须 设 定 本 页 面 “ 限 制 对 页 访问 ”的 服 
务 器 行为 。 单 击 “ 服 务 器 行为 ”面板 上 的 四 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 用 户 身份 验证 ” 
一 “限制 对 页 的 访问 ”命令 ， 打 开 “ 限 制 对 页 的 访问 ”对 话 框 ， 选 择 “ 用 户 名 和 密码 ” 单 
选 按钮 ， 如 果 访 问 被 拒绝 页 面 ， 将 转向 admin login. php, WE 8-78 所 示 。 








动态 网 站 开发 从 入 门 到 精通 











O 用 户 名 、 FEBS 








选取 级 别 : 2 














如 果 访 问 被 拒绝 ， 则 转 到 : admin login. php 








E...) 
] 





图 8-78 限制 对 页 面 的 访问 设置 


SES 删除 讨论 页 面 





删除 讨论 页 面 del, title. php 的 功能 不 只 


是 要 删除 所 指定 的 主题 ， 


还 要 将 与 此 主题 相关 的 


回复 留言 从 资料 表 bbs ref 中 删除 。 页 面 设计 效果 如 网 8-79 所 示 。 
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图 8-79 ”删除 讨论 页 面 的 设计 效果 


详细 操作 步骤 如 下 。 
1) 打开 删除 讨论 页 面 del title. php， 单 击 “ 应 


应 用 程序 ”面板 群 组 中 “ 绑 定 ”面板 上 的 


由 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 记 录 集 (查询 ) ”的 命令 ， 在 打开 的 “记录 集 ” 对 话 框 
中 单 击 “高 级 ”按钮 ， 进 入 记录 集 高 级 设 定 的 页 面 ， 将 现 有 的 SQL 语句 改 成 以 下 的 SQL 语 


句 ， 如 图 8-80 所 示 。 


SELECT bbs main. * ,bbs ref. * 
FROM bbs. main LEFT OUTER JOIN bbs, ref ON 
WHERE bbs. main. bbs ID + ". $bbs ID. " 


bbs, main. bbs, ID = bbs ref. bbs. main, ID 












»e o o0 e o « eoo€ 
2500060600065: 0000000 
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OG 5». 90989908 a s — f z 
60600 eee oo. : <... e 00060 09 Js BBS 论坛 管理 系统 











名 称 : rs 


Bs e] 


SQL: SELECT bbs main. *, bbs ref.* 
FROM bbs main LEFT OUTER JOIN bbs ref ON 
bbs main.bbs Il-bbs ref.bbs main ID 
WHERE bbs main.bbs ID -'".$bbs ID." 



































图 8-80 改写 SQL 语句 
2) 上 图 中 设置 了 一 个 名 为 $bbs_ID 的 变量 值 ， 即 是 admin. php 传递 过 来 的 参数 ， 因 此 
在 该 页 自动 生成 的 PHP 代码 中 的 第 1 行 加 入 如 下 的 变量 赋值 。 
$bbs_ID = strval($_GET{ bbs ID ] ) ; 


3) 在 设 定 完 记 录 集 绑 定 后 ， 把 rs 记录 集中 的 字段 搬入 到 del title. php. 页 面 上 ， 如 
图 8-81 所 示 。 


z C: \Apache\htdocs\bbs\del_title. php 


Dat bbs. php 





2| x 


b. od 


&- ”PHP 论 坛 管理 系统 





你 确定 册 除 此 标题 和 内 容 : 
标题 : T irs.bbs title] 


"[rs.bbs content] 





mi 
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图 8-81 字段 插 人 至 del title. php 中 









QL4*Dreamweaver 





4) 在 页 面 中 插入 一 个 隐藏 字段 bbs_ID ， 将 这 个 变量 绑 定 至 删除 讨论 页 面 del title. php 
中 的 隐藏 区 域 bbs ID， 如 图 8-82 所 示 。 
属性 


区 Fax btt 
bbs ID IHV) [<?php echo $row rs[' bbs ID]; ?> 多 
































图 8-82 ”插入 字段 到 隐藏 域 中 


5) 完成 页 面 的 字段 布置 后 ， 接 着 要 在 del ute. php 页 面 加 入 “删除 记录 ”的 设置 ， 具 
体 的 设置 如 图 8-83 所 示 。 
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图 8-83 设置 “删除 记录 ”对 话 框 
单 击 “ 确 定 ”按钮 ， 完 成 删除 讨论 页 面 的 设置 。 


ener 修改 讨论 主题 


修改 讨论 主题 页 面 upd_title. php 的 功能 是 更 新 主题 的 标题 和 内 容 到 bbs_main 数据 表 中 ， 
页 面 设计 如 图 8-84 所 示 。 
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图 8-84 修改 讨论 主题 页 面 效 果 


动态 网 站 开发 从 入 门 到 精通 





BBS 论坛 管理 系统 


操作 步骤 如 下 。 

1) 打开 修改 讨论 主题 页 面 upd_title. php， 单 击 “ 绑 定 ” 面 板 上 的 四 按钮 ， 在 弹出 的 菜 
单 中 ， 选 择 “记录 集 (查询 ) ”命令 ,， 在 打开 的 “记录 集 ” 对 话 框 中 ， 单 击 “ 高 级 ”按钮 ， 
进入 记录 集 高 级 设 定 页 面 ， 将 现 有 的 SQL 语句 改 成 以 下 的 SQL 语句 ， 如 图 8-85 所 示 : 

SELECT bbs main. * ,bbs ref. * 


FROM bbs main LEFT OUTER JOIN bbs ref ON bbs main. bbs ID = bbs ref. bbs main. ID 
WHERE bbs. main. bbs ID + ". $bbs ID. " 















































取消 
连接 : [bbs a i) : 
3i 
SQL: SELECT bbs nain.*, bbs E 
Hl bbs ; main LEFT DUTER EOD bbs ref ON 简单 . a 
mm in.bbs ID-bbs ref, bbs nain ID i 
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图 8-85 改写 SQL 语句 
2) 图 8-91 中 设置 了 一 个 名 为 $bbs_ID 的 变量 值 ， 即 是 admin. php 传递 过 来 的 参数 ， 
此 在 该 页 自动 生成 的 PHP 代码 中 的 第 一 行 加 入 如 下 的 变量 赋值 。 


$bbs_ID = strval($ GET[ bbs ID ]); 


3) 在 设 定 完 记录 集 绑 定 后 ， 把 记录 集 rs 中 的 字段 搬入 到 upd. title. php 页 面 上 ， 如 
图 8-86 所 示 。 


T C: wpachevhtdocs\bbsvupd_title php 站 


bbs. php 
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图 8-86 字段 插入 至 upd_title. php 中 
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4) 在 页 面 中 插入 一 个 隐藏 字段 bbs_ID ， 将 这 个 变量 绑 定 至 修改 讨论 主题 页 面 upd. ü- 
tle. php 中 的 隐藏 域 bbs_ ID, ， 如 图 8-87 所 示 。 


属性 





IN BREH 

















ÍB(V) |Cphp echo $row_rs[ bbs ID']; ?> 多 





图 8-87 插入 字段 到 隐藏 区 域 中 


5) 完成 页 面 的 字段 布置 后 ， 接 着 要 在 upd ue. php 加 入 “更 新 记录 ”的 设置 。 在 “更 
新 记录 ”对 话 框 中 ， 输 入 如 图 8-88 所 示 的 设置 。 
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在 更 新 后 ， 转 到 : admin. php 





n CIE 
as 




















图 8-88 设置 “更 新 记录 ” 对 话 村 


THI 





6) 单 击 “ 确 定 ”按钮 ， 完 成 修改 讨论 主题 页 面 的 设置 。 


SSS MEEDOEN HA 


删除 回复 页 面 del. reply. php 功能 是 将 表单 中 的 数据 从 网 站 的 数据 表 bbs. ref 中 删除 。 其 
主要 目的 是 ， 管 理 员 对 一 些 不 文明 和 非法 的 回复 信息 进行 删除 。 其 页 面 设计 效果 如 图 8-89 


所 示 。 


其 详细 的 操作 步骤 如 下 。 

1) 打开 后 台 版 主管 理 页 面 admin. php 单 击 标题 ， 进 入 del reply. php 页 面 。 实 现 此 功能 时 ， 
只 要 在 标题 的 属性 栏 将 链接 到 的 页 面 参数 修改 为 del_reply. php 就 可 以 ， 如 图 8-90 所 示 。 

2) 在 del_reply. php 页 面 ， 单 击 “ 绑 定 ” 面 板 上 的 轩 按 钮 ， 在 弹出 的 菜单 中 ， 选择 
“记录 集 (查询 ) ”命令 ， 在 打开 的 “记录 集 ” 对 话 框 中 ， 单 击 “ 高 级 ”按钮 ， 进 入 记录 集 
高 级 设 定 页 面 ， 将 现 有 的 SQL 语句 改 成 以 下 的 SQL 语句 ， 如 图 8-91 所 示 。 

SELECT bbs main. * ,bbs ref. * 


FROM bbs main LEFT OUTER JOIN bbs. ref ON bbs main. bbs ID = bbs ref. bbs main. ID 
WHERE bbs. main. bbs ID + ". $bbs ID. " 
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del_reply.php x 
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images 
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admin. php 11KB PHP 
admin login php SKB PHP 
bbs add php 10KB PHP 
bbs reply.php 9KB PHP 
content. php 11KB PHP 
del ref. php 4KB PHP 
del reply.php PHP 
del title. php SKB PHP 
index.php 9KB PHP 
wpd title. php BKB PHP 
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图 8-90 属性 链接 设置 










































数据 库 项 : | 田 七 ”表格 
p 视图 
d. ”预存 过 程 
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SQL: SELECT bbs main.*, bbs ref. * n = 

FROM bbs main LEFT OUTER JOIN bbs ref ON 一 简单 

bbs_main bbs_ID=bbs_ref., bbs main ID 


WHERE bbs main.bbs ID -'".$bbs ID." OB 

















图 8-91 改写 SQL 语句 


3) 在 该 页 自动 生成 的 PHP 代码 中 的 第 1 行 加 入 如 下 的 变量 赋值 。 


$bbs_ID 2strval($ GET[ bbs ID ]); 











CIL 


4) 在 设 定 完 
图 8-92 所 示 。 
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记录 集 绑 定 后 ， 把 记录 集 rs 中 的 字段 插入 到 del reply. php REE, AH 
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图 8-92 ”字段 搬入 至 del reply. php 中 











5) 在 页 面 中 搬入 一 个 隐藏 字段 bbs_ID ， 将 这 个 变量 绑 定 至 删除 回复 页 面 del, reply. php 
中 的 隐藏 区 域 bbs_ ID, ， 如 图 8-93 所 示 。 


属性 
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Fax ett 
bbs ID 


























j av php echo $row rsl bbs ID. E ?7 
图 8-93 ”插入 字段 到 隐藏 域 中 


6) 完成 页 面 的 字段 布置 后 ， 接 着 要 在 del reply. php REMA “WREE”? WERE, K 
要 在 “删除 记录 ”对 话 框 中 ,输入 如 图 8-94 所 示 的 设置 。 
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首先 检查 是 否 已 定义 变量 : 
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数值 





主键 值 : URL 参数 »|bbs ref ID 


WE. dem ‘admin. php 














图 8-94 设置 “删除 记录 ”对 话 框 
HH: aM. 


到 这 里 就 完成 了 BBS 论坛 系统 的 开发 制作 ， 读 者 可 以 凭借 学 
化 的 论坛 ， 通 过 加 入 更 多 的 技术 ， 可 以 完成 更 强大 的 Web 程序 。 


Hi 





习 到 的 知识 来 做 一 个 个 性 





eB 9 = ”PHP 网 上 购物 系统 前 台 


本 章 介绍 一 个 使 用 PHP 开发 的 大 型 电子 商务 网 站 的 建设 实例 。 网 上 购物 系统 是 由 专业 
网 络 技术 公司 开发 ， 是 拥有 产品 发 布 、 订 单 处 理 、 购 物 车 等 功能 组 合 而 成 的 复杂 动态 系统 。 
它 必 须 拥 有 会 员 系 统 、 查 询 系统 、 购 物流 程 、 会 员 服务 、 后 台 管理 等 功能 模块 ， 从 技术 角度 
来 说 ， 主 要 是 通过 购物 车 实现 电子 商务 功能 。 本 章 主 要 介绍 使 用 PHP 进行 网 上 购物 系统 前 
台 开 发 的 方法 ， 将 系统 地 介绍 网 上 购物 系统 的 设计 、 数 据 库 的 规划 以 及 常用 的 几 个 功能 模块 
前 台 的 开发 方法 。 


EL VAVBESEIGU 


主要 掌握 以 下 知识 点 : 


网 上 购物 系统 的 功能 分 析 与 模块 设计 
网 上 购物 系统 数据 库 的 设计 搭建 
购物 车 首页 的 设计 

商品 相关 动态 页 面 设计 

商品 结算 功能 设计 
订单 查询 功能 设计 
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网 上 购物 系统 分 析 与 设计 


网 上 购物 系统 是 一 个 比较 庞大 的 系统 ， 拥 有 会 员 系 统 、 查 询 系统 、 购 物流 程 、 会 员 服 
务 、 后 台 管 理 等 功能 模块 。 为 了 能 系统 化 地 介绍 使 用 PHP 建设 电子 商务 网 站 的 过 程 ， 本 章 
将 模拟 一 个 实用 的 购物 网 站 的 建设 过 程 为 例 ， 来 详细 介绍 网 站 想 拥有 一 个 网 上 购物 系统 必须 
做 哪些 具体 工作 。 


JO 购物 系统 分 析 


商务 实用 型 网 站 是 在 网 络 上 建立 一 个 虚拟 的 购物 商场 ， 让 访问 者 在 网 络 上 购物 。 网 上 购 
物 以 及 网 上 商店 的 出 现 ， 避 免 了 挑选 商品 的 烦琐 过 程 ， 让 人 们 的 购物 过 程 变 得 轻松 、 快 捷 、 
方便 ， 适 合 现代 人 快 节奏 的 生活 需求 ， 同 时 又 能 有 效 地 控制 “商场 ”运营 的 成 本 ， 开 辟 了 
一 个 新 的 销售 渠道 。 本 实例 是 使 用 PHP + MySQL 直接 用 手写 程序 完成 的 实例 ， 完 成 的 首页 
如 图 9-1 所 示 。 
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图 9-1 开发 设计 的 网 上 购物 系统 首页 效果 

对 于 该 网 站 的 功能 说 明 如 下 。 

1) 采取 会 员 制 保证 交易 的 安全 性 。 

2) 开发 了 强大 的 搜索 以 及 高 级 查询 功能 ， 能 够 快捷 地 找到 感 兴趣 的 商品 。 

3) 会 员 购物 流程 : 浏览 、 将 商品 放 入 购物 车 、 去 收银 台 。 每 个 会 员 有 自己 专用 的 购物 
车 ， 可 随时 订购 自己 中 意 的 商品 、 结 账 完成 购物 。 购 物 的 流程 是 指导 编写 购物 车 系统 程序 的 
主要 依据 。 

4) 完善 的 会 员 中 心服 务 功能 : 可 随时 查看 账目 明细 、 订 单 明细 。 

5) 设计 会 员 价 商品 展示 ， 能 够 显示 企业 近期 所 促销 的 一 些 会 员 价 商品 。 











6) 人 性 化 的 会 员 与 网 站 留言 以 及 产品 评价 系统 ， 可 以 方便 会 员 与 网 站 管理 员 之 间 的 
沟通 o 

7) 后 台 管理 使 用 本 地 数据 库 ， 保 证 购物 订单 被 安 人 全、 及时、 有效 地 处 理 。 强 大 的 统计 
分 析 功 能 ， 便 于 管理 员 及 时 了 解 财 务 状况 、 销 售 状况 。 


JUPE 功能 模块 分 析 


通过 对 系统 功能 的 分 析 ， 得 到 网 站 的 网 上 购物 系统 主要 由 如 下 功能 模块 组 成 。 

1) 前 台 网 上 销售 模块 。 指 客户 在 浏览 器 中 所 看 到 的 、 可 直接 与 店主 面对面 的 销售 程 
序 ， 包括 浏览 商品 、 订 购 商 品 、 查 询 订购 、 购 物 车 等 功能 。 

2) 后 台数 据 录入 模块 。 前 台所 销售 商品 的 所 有 数据 ， 其 来 源 都 是 后 台所 录入 的 数据 。 

3) 后 台数 据 处 理 功 能 模块 。 它 是 相对 于 前 台 网 上 销售 模块 而 言 ， 网 上 销售 的 数据 都 放 
在 销售 数据 库 中 ， 对 这 部 分 的 数据 进行 处 理 ， 是 后 台数 据 处 理 模块 的 功能 。 

4) 用 户 注册 功能 模块 。 用 户 不 一 定 立即 就 要 买 东西 ， 可 先 注册 ， 任 何 时 候 都 可 以 来 买 
东西 。 用 户 注 册 的 好 处 在 于 买 完 东 西 后 无 须 再 输入 一 大 堆 个 人 信息 ， 只 需 将 账号 和 密码 输入 
就 可 以 了 。 

5) 订单 号 模块 。 客 户 购买 完 商 品 后 ， 系 统 自动 分 配 一 个 购物 号 码 给 客户 ， 以 方便 客户 
随时 查询 账单 处 理 情 况 ， 了 解 实 时 的 物流 信息 。 

6) 会 员 留言 模块 。 客 户 能 及 时 反馈 信息 ， 管 理 员 能 在 后 台 实现 回复 的 功能 ， 真 正 做 到 
处 处 为 顾客 着 想 。 


J 网 站 整体 规划 


在 制作 网 站 之 前 ， 首 先 要 把 设计 好 的 网 站 内 容 放 置 在 本 地 计算 机 的 硬盘 上 ， 为 了 方便 站 
点 的 设计 及 上 传 ， 设 计 好 的 网 页 都 应 存储 在 一 个 目录 下 ， 再 用 合理 的 文件 夹 来 管理 文档 。 在 
本 地 站 点 中 应 该 用 文件 夹 来 合理 构建 文档 的 结构 。 首 先 为 站 点 创建 一 个 主要 文件 夹 ， 然 后 在 
其 中 再 创建 多 个 子 文件 来， 最 后 将 文档 分 类 存储 到 相应 的 文件 夹 下 。 读 者 可 以 打开 附 赠 资源 
中 的 素材 ， 看 第 9 章 的 站 点 文档 结构 及 文件 夹 结构 ， 设 计 完 成 的 结构 如 图 9-2 所 示 。 
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图 9-2 网 站 文档 及 文件 夹 结 松 
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从 站 点 规划 的 文件 夹 及 完成 的 页 面 出 发 ， 分 别 对 需要 设计 的 页 面 功能 分 析 如 表 9-1 


站 点 规划 的 页 面 功能 分 析 




















































































































网 站 前 台 文件 
addgouwuche. php 添加 订购 的 商品 到 购物 车 gouwuche. php 页 面 
agreereg. php 同意 注册 页 面 
bottom. php 网 站 底部 版 权 
changeuser. php 户 注册 信息 更 改 页 面 
changeuserpwd. php 更 改 登录 密码 页 面 
chkuser. php 登录 身份 验证 页 面 
chkuserne. php 检查 昵称 是 否 被 用 文件 
conn/conn. php conn 文件 夹 下 的 数据 库 连 接 文件 
deleteall. php 删除 用 户 处 理 页 面 
finddd. php 订单 查询 页 面 
findpwd. php 找 回 密码 功能 的 页 
serchorder php 查找 到 商品 显示 页 面 











function. php 








系统 调用 的 常用 末 数 














gouwuche. php 











购物 车 页 面 



































gouwusuan. php 必 银 台 结 算 页 面 
highsearch. php 高 级 查找 页 面 
index. php 网 站 购物 车 首页 
























































left. php 户 及 公告 系统 
logout. php 户 退 出 页 
lookinfo. php 详细 商品 信息 





openfindpwd. php 








































































































reg. php 户 注册 开始 页 面 
removegwc. php 购物 车 移 除 指定 商品 页 面 
savechangeuserpwd. php 更 改 用 户 密码 页 面 
savedd. php 保存 用 户 订单 页 面 
savepj. php 保存 商品 评价 页 面 
savereg. php 保存 用 户 注册 信息 
saveuserleaveword. php 保存 用 户 留 言 页 面 
showdd. php 显示 详细 订单 页 面 
showfenlei. php 商品 分 类 显示 页 面 

















gonggao. php 





显示 详细 公告 内 容 页 面 








gonggaolist. php 

















公告 罗列 分 页 显示 页 面 








showhot php 








热门 商品 页 面 





shownewpr. php 

















最 新 商品 页 面 








态 网 站 开发 从 入 门 到 精通 




















CEMRE 












































(E) 
网 站 前 台 文 件 主要 功能 
showpp. php 商品 销售 排行 页 面 
showpl. php 商品 评论 分 页 显示 页 面 E 
showpwd. php 用 户 找 回 的 密码 页 面 
showtuijian. php 推荐 商品 页 面 
top. php 网 站 顶部 导航 条 
usercenter. php 会 员 中 心 页 面 
userleaveword. php 发 表 留 言 页 面 


从 上 面 的 分 析 统 计 来 看 ， 该 网 站 前 台 


有 的 功能 设计 。 


























购物 系统 数据 库 设计 


共 由 41 个 页 面 组 成 ， 几 乎 涉及 了 动态 网 站 建设 所 


网 上 购物 系统 的 数据 库 也 是 比较 庞大 的 ， 在 设计 的 时 候 需 要 从 使 用 的 功能 模块 人手， 
可 以 分 别 创建 不 同 命名 的 数据 表 ， 命 名 的 时 候 也 要 与 使 用 的 功能 命名 相配 合 ， 方 便 后 面 
相关 页 面 设计 制作 时 的 调用 。MySQL 数据 库 的 制作 方法 在 前 面 的 章节 中 也 介绍 过 很 多 次 ， 
本 章节 将 要 完成 的 数据 库 命 名 为 db_shop ， 在 数据 库 中 建立 8 个 不 同 的 数据 表 ， 如 图 9-3 


所 示 。 











Gc 














Pu 127.0.0.1 / 127.0.0.1 / db... X 





phpMyAdmin 
$90€ 
| 曝 近 使 用 的 表 ) . 














LA j bbs 

(5 cdcol 

[+= 4 db shop 

He. gbook 

GÆ information schema 


$a performance_schema 
H 4 phpmyadmin 


Œ 4 phpweb 
a test 
G&H vote 
=H 4 webauth 


加 服务 器 : 127.0.0.1 > E: db_shop 








































































































Wt aa B sa S iE 国 查 向 居中 E) RA S BE Sv Ss 
ka 操作 i 类 型 。 “排序 规则 
[7] 
tb admin 司 浏览 yet c» 搜索 xe dE. AMAT @@ 删除 1 MyISAM gb2312 chinese 
tb dingdan | |3/5 WA 过 搜索 x d&A fg OMA 1 MyISAM gb2312 chinese 
tb gonggao 国 浏览 MAA c 搜索 Re füA Secr OMPA 5 MyISAM gb2312 chinese - 
-] tb leaveword JX PA 19x: ORA RAT 回 删除 0 MyISAM gb2312 chinese 
tb pingjia 司 浏览 WT 名 搜索 ed gs Qmm 0 MyISAM gb2312 chinese 
= tb shangpin JAA PA 名 搜索 pA MOAT 加 删除 4 MyISAM gb2312 chinese 
F) tb type DAt 项 结构 dp fex HMA RAT OMA 4 MyISAM gb2312 chinese 
=) tb user 辐 浏 览 驴 结 构 名 搜索 MA RAT 四 删除 3 MyISAM gb2312 chinese 
8 张 表 i 18 InnoDB latin! swedish 一 
t. 回 全 选 / 仅 选 择 多 余 。 ”| 选中 项 : x 
& HEA gà 数据 字典 
(-| taR | 











ET) 


个 人 -| 上 http://127.0.0.1/phpmyadmin/£PMAURL-1:db structure.php?db-db shop&table-&server-l&target-&tc $ O ~ ÈX 


























图 9-3 建立 的 db shop 数据 库 









QL-*-Dreamweaver 动态 网 站 开发 从 入 门 到 精通 


DIESE 设计 数据 表 





数据 库 db. shop 里 是 根据 开发 网 站 的 几 大 动态 功能 


设计 不 同 数据 表 的 ， 本 实例 需要 创 
建 8 个 不 同 的 数据 表 。 下 面 分 别 介 绍 这 些 数据 表 的 功能 及 设计 的 字段 要 求 。 

1) tb. admin 是 用 来 储存 后 台 管 理 员 的 信息 表 ， 设计 的 也 _admin 数据 表 ， 如 图 9-4 所 
示 。 其 中 name 是 管理 员 名 称 ，pwd 是 管理 员 密 码 。 





Les 
H| ^ ~ |4 http://127.0.0.1/phpmyadmin/sPMAURL-2:bl structure.php?db-db shop&table-tb admin&server-l&target-&token-c d! JO ~ ÈX 
Aih 127.0.0.1 / 127.0.0.1 / db... X 

















A ve (9 

























































































phpMyAdmin 一 | 苛 服务 器 : 127.0.0.1 » © 数据 库 : db. shop » fi : tb. admin 
$8498 Lj 浏览 H 5569 g sQL à HERO XP MA BH E) SA 4 ERO 更 多 
| OERA) —. - # 名 字 类 型 排序 规则 属性 空 黔 认 额外 操作 
E PW ac emi 加 1 过 int(4) $80 P € QE 力主 键 国 唯 一 更 多 
2 j n A| rj 2 name varchar(25) gb2312 chinese ci 是 NULL SR ON out- vE 
e 3 db, shop 回 3 pwd varchar(50) gb2312 chinese ci 是 NULL a? QE PEREN- vE 
EL 
uis. t Uk cem DAR sën OME PHE B- BA mms 
eod tb dingdan qp 全 文 搜索 
Gri] tb. gonggao & 打印 预览 D 关系 查看 M RANO © EBRD PFR E 
p 可 tb leaveword €— 
市 可 1b. pingjia gosm |1 [1 |o FRAR © FRAZ © 于 之 后 [ld 回 | -] (执行 
eod ib shangpin + 索引 
eu tb type L Ig TH 
GH] tb user | 信息 | 
EH gbook 
$e a information schema 已 用 空间 aaa 
= 4) member x 
Ha mysal 数据 64 字 节 格式 36 
8.3 news ssl 2 KB 排序 规则 。 352312 chinese ci 
GH performance schema Mi 2.1 KB 行 数 1 
H 3} phpmyadmin 行 长 度 64 字 节 
es phpweb LJ 行 大 小 2,112 字 节 
í test 
H 创建 时 间 2007-11-27 19:43:42 
= BCE 
9-4 后 台 管理 者 表 tb admin 


2) tb. dingdan 是 用 来 储存 会 员 在 网 上 下 的 订单 的 详细 内 容 表 ， 
表 ， 如 图 9-5 所 示 。 


IFKS tb. dingdan 数据 



















































































一 人 5! X 
aa 
> 
I^ phpMyAdmin : 127.0.0.1 » 图 数据 库 db_shop » 加 表 : tb_dingdan 
QBRonse Das H ga E sa 马 XP A BI 5 SA Aer ov ws | 
| (最近 使 用 的 表 ) ， = # 名 字 类 型 排序 规则 z ZA 额外 E: 
EH cdcol “| 回 id int(4) 1 五 AUTO INCREMENT 4? ££ Q Mi m 
eus Nd 2 dingdanhao varchar(125) gb2312 chinese ci Æ NULL QÉR GOES ER 
eu ib admin Ej 3spc varchar(125) gb2312 chinese ci ”是 NULL Pi OM 更 多 1 
GH] tb dingdan F] 4 sic varchar(125) gb2312 chinese ci ”是 NULL €x QNS 了 更 多 
en bte rd [] 5 shouhuoren varchar(25) gb2312 chinese ci 是 NULL JEA OMi v 更 多 
$i in] tb pingjia r] 6 sex varchar(2) —gb2312 chinese ci ”是 NULL QUT Oii vE 
GHE] tb_shangpin 回 7 dizhi varchar(125) gb2312_chinese ci Æ NULL Jn QE 更 多 |] 
E S s [] 8 youbian varchar10) gb2312 chinese ci — f£ NULL JE Om 34 
ŒH 3 gbook E 9 tel varchar(25) gb2312 chinese ci 是 NULL JEA QNS 更 多 
fi information schema = 10 email varchar25) gb2312 chinese ci Æ NULL UEM ONE 55 
i 3 Bis 11 shff varchar(25) gb2312 chinese ci 是 NULL JEA QNS 
G 3J news rj 12 zfff varchar(25) gb2312 chinese ci ”是 NULL € QN 9 
p 3 SE EIER E 13 leaveword mediumtext gb2312 chinese ci ”是 NULL JUR OM vE 
es J phpweb T 14 time varchar(25) gb2312 chinese ci ”是 NULL Um OM E 
EH 5 test 15 xiadanren varchar(25) gb2312_chinese ci 是 NULL 上 个 QE 更 多 | 
^ 3 Mud n MD 16 zt varchar(50) gb2312 chinese ci 是 NULL 修改 QI vE 
42 antet — PEPPA mem 


























图 9-5 用 户 订单 表 也 _dingdan 








人 人 PHP 网 上 购物 系统 前 台 





3) tb gonggao 是 用 来 保存 网 站 公告 的 信息 表 ， 设 计 的 tb. gonggao 数据 表 ， 如 图 9-6 
所 示 。 




















































































| 
ARE dla http://127.0.0.1/phpmyadmin/sPMAURL-5:tbl structure.php?db-db shop&table-tb gonggao&server-l&target-&toke X P » X| (5) vy 9? 
Aù 127.0.0.1 / 127.0.0.1 / db... X 
phpMyAdmin | EEZCXZLIETETZ imc 
see Oak w^ a LJ sQL 及 搜索 EMA d SH 图 导入 A BHO v me 
| ERTE) - - s» WO NS 排序 规则 属性 空 默认 ”额外 操作 
"ES B 1 这 int(4) A Æ — AUTO INCREMENT 4? £k @ 删除 wmm 
rds db shop ^| E 2 tile — varchar100) gb2312 chinese ci f NULL J € QE 25 
Ha 新 建 4| m 3 content tex gb2312 chinese ci 是 NULL s^ 加 删除 了 更 多 
围 司 tb admin 2 
EEE t óngcan 回 4 ime varchar(25) gb2312 chinese ci f NULL J Eh QE 更 多 
[Biz] tb-gonagao t DSt sem (A JEn ONE AE B xk mH | 
AHO tb leaveword - 
E > 国 全 文 搜索 
HE tb_pingjia 
SH] tb_shangpin & 打印 预览 唱 关系 查看 M RAHO © EBRD 移动 字段 
Grad type gps |1 个 字段 @ FRAR O PRAA O 于 之 后 |d E) ifr) 
GH tb user ee T 
ies gbook = + 索引 
4*— s information schema = 
H .j member | 信息 | 
Ea mysql 
a news 已 用 空间 Row statistics 
& 3j ER 数据 4.6 KB 格式 动态 
"i cum 索引 2 KB 排序 规则 gb2312_chinese_ci 
í US dd 多 余 2.4 KB 行 数 5 
FH j vote | 有 效 4.1 KB 行 长 度 439 字 节 
(i-i. webauth al 总 计 6.6 KB 行 大 小 1,350 F$ S 


























图 9-6 网 站 公告 表 了 由 _gonggao 


4) tb leaveword 是 用 户 给 网 站 管理 者 留言 的 数据 表 ， 设 计 的 tb_leaveword 数据 表 ， 如 
图 9-7 所 示 。 


































































































EI) 
$4&90€ Oak w^ a 局 SQL 及 搜索 EMA 03 So 图 导入 ^ BHO v me 
| (最 折 使 用 的 表 ) - depo nm 排序 规则 E ZA h 操作 
EH cdcol a| El 1 id int(4) 1; Æ AUTO INCREMENT 多 修改 QUIS rub 
后 -本 db shop 下 更 多 
La 新 建 ^d rj 2 userid int(4) 是 NULL ER OE ors 
GHI tb admin 95 
GHE] tb. dingdan 回 3 title ^ varchar(67) utf& general ci 是 NULL JE OM AR 
firi] tb gonggao vE 5 
GH] tb_leaveword 4 content text utf8 general ci 是 NULL 2 Eh Om PTR 
H to_pingjia vē% 
GH] tb_shangpin 回 5 time — varchar(17) uff general ci 是 NULL Jw QNS PER 
H tb ype 了 更 多 
SH tb user 
GH gbook J| t. DS E95 国 浏览 JEn OM: 2t T- gR [Y Wie 
$a information schema ^J m 全 文 搜索 
a5 & 打印 预览 公关 系 查看 M 规划 未 结构 Q © EBRD PIFR E 
E-a news gom 个 字段 @ FREAR O PRAA O 于 之 后 |d 回 | Afr) 
H a performance schema + 索引 
由 -3 phpmyadmin 
FH 3 phpweb m 信息 | 
88-5 test 
gave 已 用 空间 Row statistics 
二 -本 webauth 
二 og n ikt des - 
图 9-7 HP ELSE tb. leaveword 











5) tb. pingjia 是 用 户 对 网 上 商品 的 评价 表 ， 设 计 的 由 _pingjia 数据 表 ， 如 图 9-8 
所 示 。 

6) tb shangpin 是 商品 表 ， 购 物 系统 中 核心 的 产品 发 布 ， 定 购 时 的 结算 都 要 调用 该 数据 
表 的 内 容 ， 设 计 的 也 _shangpin 数据 表 ， 如 图 9-9 所 示 。 

7) tb type 是 商品 的 分 类 表 ， 设 计 的 由 _type 数据 表 ， 如 图 9-10 所 示 。 
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[HET 














个 人 ~ | la httpi//127.0.0.1/phpmyadmin/&PMAURL-9:bI structure.php?db-db. shop&table-tb pingjia&server-i&target-&token- d? D ~ X 








id, 127.0.0.1 / 127.0.0.1 / db... x a] 






























































































phpMyAdmin EE 
$5&9)€ Lj mH Wt fg O sa à df E (2 SU) 0) SA A Bf v m6 
| 最近 使 用 的 表 ) zl # 名 字 nm 排序 规则 E zA HOM HE 
Ha cdcol “| 回 1 地 int(4) Æ Æ — AUTO INCREMENT p f£? QNS rut 
后 -本 db shop 更 多 
EL 加 器 2 userid int(4) 是 NULL JUR QE ora 
SH] tb admin 更 多 
CT tb_dingdan | Fi 3 spid in) f NULL JE ONE rg E 
eu ib gonggao bd 
HE tb leaveword O 4 tile — varchar(67) utf8 general ci 是 NULL Um oae ofr 
e 1b pingjia 下 更 多 
GHE tb. shangpin E 5 content text utf8 general ci 是 NULL Um eS 5r 
GHE tb type | 下 更 多 
| Gi 中 user 回 6 time — varchar(17) utf8 general ci 8 ER QNM or 
Gi gbook d 52 
H information schema | 
i. member t. DSt Gm. 国 浏览 Jeh Om it u- DAI 隅 空间 uj 
E-a mysql qp 全 文 搜索 
i 
vin E la TEG XEDE M AUS S D EBRD BIFE 
H3 phpmyadmin on 1 个 字段 @@ 于 表 结尾 © 于 表 开头 © 于 之 后 | d 到 | (fr 
#3 phpmy: F | | Ge 
刻本 phpweb EJ 
GH test — 
Ea vole | 信息 | 
转 -3 webauth | p 
| 
HH Y . T 
图 9-8 商品 用 户 评价 表 tb. pingiia 
[NEP 











je 


AA 7 | is http;//127.0.0-/phpmyadmin/fPMAURL-11b] structure.php?db-db shop&table-tb shangpin&serverl&target-&tok: $ D ~ ÈX 





O y i93 








ji, 127.0.0.1 / 127.0.0.1 / db... x a] 








































































phpMyAdmin IRSE: 127.0.0.1 » @ 数据 库 : db_shop » E: tb_shangpin 
$2909 Lj m Hea D sa A d£ EM 03 SEO 图 导入 ^ Ef 更 多 

| 最近 使 用 的 表 ) - # 名 字 类 型 排序 规则 H ZWA dm TE 
BH cdcol 1 id int(4) 否 无 。 AUTO_INCREMENT p 18 QM ves 
La pia 2 mingcheng varchar(25) gb2312 chinese ci ”是 NULL JUR QNS 更 多 

SH] tb. admin 3 jianjie mediumtext gb2312 chinese ci ”是 NULL £P QI m5 5 

ea tb_dingdan 4 addtime varchar(25) gb2312 chinese ci 是 NULL 24 QI 25 

IH ] tb gonggao > 

TN 3 5 dengji varchar(5)  gb2312 chinese ci — 是 NULL Un ONUS v 更 多 

ei =] tb_pingjia 6 xinghao  varchar(25) gb2312 chinese ci — f£ NULL ER QNS 更 多 

gc] tb shangpin 7 tupian varchar200) gb2312 chinese ci ”是 NULL £^ UR QE 

+ tb 

2a E 8 shuliang — in(4) 是 NULL UR QE m5 — 
EH gbook 9 cishu int(4) 是 NULL Jw ONES v 更 多 
H} information schema x x š 

10 tuijian int(4) 是 NULL JE QNS 更 多 
H3 member 
Ea mysql 11 typeid int(4) 是 NULL JU QNS v 更 多 
&- j| news 12 huiyuanjia varchar(25) gb2312 chinese ci — f£ NULL JEn QNS m5 
NEN ca 13 shichangjia varchar(25) gb2312 chinese ci {Œ NULL Jm ONE ms 
南 - phpmyadmin 
&-3 phpweb 14 pinpai varchar25) gb2312 chinese ci 是 NULL JEn QNS wv 更 多 
(3 test. à -" 
Ea vote t DSt Gem 国 浏览 ëh O0 NR ^ r9 B- oA 阳 空 间 
Œ webauth 到 m 全 文 搜索 d 
ri . 
图 9-9 商品 表 由 _shangpin 
fem 











phpMyAdmin 

aee 

| ERARE 
WH cdcol 
后- db shop 

cus 
GH tb. admin 
F E] tb_dingdan 





4 











E] 1 过 


T. DSt Gem 


m 全 文 搜索 


[s] 


© 数据 库 : db shop 2: 
Lj ms M ea Lj sa 
# 名 字 类 型 
int(4) 
E 2 typename varchar(17) utf8 general ci 









理 无 
是 NULL 


浏览 o€R ONE 






4 PES EIA (o mh D SA ABE 
HOO MERS GEM 
AUTO INCREMENT 4? (ZP Omè 585 


p 主键 





HE | 


JE» QE VES 


p- BI B 2a 





GH] tb_gonggao 
SH] tb. leaveword | 

















& 打印 预览 唱 关系 查看 M REO © 追 时 表 可 移动 字段 
























































店 司 tb pngla |n |1 | FRO FREAR O 于 来 开头 O 于 之 后 | 可 E 

qu tb shangpin 四 + 索引 

14] tb ype í 

EH tb user 门 | 信息 
H j gbook L | 
$ information. schema | ES -— 

aj membe: SaS > 
us (oM 96 F 格式 E 
Ea news | 和 2 KB 排序 规则 gb2312_chinese_ci 
S= a performance schema 总 计 2.1 KB 行 数 4 
68-3 phpmyadmin fi 24 9 E 
fg ia phpweb 行 大 小 536 字 节 
"i-um Tra E 
y webauth Q 创建 时 间 2012-04-29 12:40:05 
= =04= 
[m] 
图 9-10 ”商品 分 类 表 tb type 








8) tb user 是 用 来 保存 网 站 会 


所 示 。 


Ey 
DUE 
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95 








【PHP 网 上 购物 系统 前 台 


册 用 的 数据 表 ， 设 计 的 tb user 数据 表 ， 如 图 9-11 
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Ee) 
HTE A http://127.0.0.1/phpmyadmin/#PMAURL-15:tbl_structure.php?db=db_shop&table=tb_user&server=1&target=&token=7 È O- CX| Q w i9? 
i 127.0.0.1 / 127.0.0.1 / db... X 
F 务 器 "TT > 
phpMyAdmin 图 鲁 服 务 8: 127.0.01 > 因数 据 库 : db_shop » 轿 表 : tb_user 
公司 @De9 Oak w^ a LJ sQL 及 搜索 EMA 03 SH 图 导入 5 BHO Y 更 多 
| (最 折 使 用 的 表 ) - a * Wr 类 型 排序 规则 x ZA 额外 TF 
EH cdcol ajo 1i int(4) 否 Æ AUTO INCREMENT 多 修改 @ 删除 wv 更 多 
ld cit IN 2 name varchar25) gb2312 chinese ci 是 NULL 224 Oi 更 多 
GHT tb. admin E 3 pwd varchar(50) gb2312 chinese ci 是 NULL JEn OMR v 更 多 |7 
GH tb dingdan fj 4 dongjie int(4) 是 NULL 外 修改 QNS v 更 多 
H] tb gonggao 里 ? 
emn SE E 5 email varchar(25) gb2312 chinese ci 是 NULL JEA @ 删除 wv 更 多 
eu ib pingjia O 6 sfzh varchar25) gb2312 chinese ci 是 NULL Hm ONE 更 多 
GH] tb. shangpin 回 7t varchar(25) gb2312 chinese ci 是 NULL 多 修改 QI 25 
H tb t 
"t Wm o 84 varchar(25) gb2312 chinese ci 是 NULL Rm ONE 
H j gbook =| 9 tishi varchar(50) gb2312_chinese_ci 是 NULL JEH @ 删除 更 多 
eis Moser E 10 huida varchar(50) gb2312 chinese ci 是 NULL UR OMS vE 
i+H a member 
$a d E 11 dizhi varchar(100) gb2312 chinese ci Œ NULL JUR ONSE "ms 
ies news E 12 youbian varchar(25) gb2312 chinese ci 是 NULL 修改 INS 55 
ŒH performance schema - x " 
$-a phpmyadmin 13 regtime varchar(25) gb2312_chinese_ci 是 NULL JEN QNS vw 更 多 
FH j phpweb 14 truename varchar(25) gb2312_chinese_ci Æ NULL 外 修改 @ 删除 更 多 
des test m 15 pwd1 varchar(50) gb2312_chinese_ci 是 NULL JEn OMR vE 
Ha vote 
l 
GH webauth -| t. DSt ze o (AA Jen OMS r9 T- SzI B TH z 
































图 9-11 网 站 用 户 信息 表 tb. user 


上 面 设计 的 数据 表 属 于 比较 复杂 的 数据 表 ， 数 据 表 之 间 主 要 通过 产品 的 类 别 ID 关联 ， 
建立 网 站 所 需要 的 主要 内 容 信息 ， 都 能 储存 在 数据 库 里 面 。 


JDD 定义 购物 车 站 点 


定义 购物 车 系统 站 点 的 具体 操作 步骤 如 下 。 
1) 首先 在 C:\xampp\htdocs 路 径 下 建立 shop 文件 夹 ， 如 图 9-12 所 示 ， 本 章 所 有 建立 
的 PHP 程序 文件 都 将 放 在 该 文件 夹 下 。 
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|: inetpub | J index.html jJ; vote 内 . mmServerScripts 
ji LYL 园 faviconjico | ii shop | 
上 PerfLogs ij bitnami.css È restricted 
用 Program File: L ]applications.html BD phpweb 
B Program File; — apache pb2 anigif — |; news 
Ji Qvodplayer | i8 apache pb2.png |; member 
5 3 apache pb2.gif |, img 
|: Windows 
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M XAMPP. iB apache pb.gif Ji forbidden 
k 用 户 - 
shop 修改 日 期 : 2014/12/10 11:14 
| | 文件 去 
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图 9-12 建立 站 点 文件 夹 shop 


2) 打开 Dreamweaver CC， 选 择 菜单 栏 中 的 “站 点 ”一 “管理 站 点 ”命令 ,打开 “管理 
站 点 ”对 话 框 ， 如 图 9-13 所 示 。 
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窗口 (W) — 帮助 (H) 
























新 建站 点 (N)… 
新 建 Business Catalyst 站 点 (B). 



































































D GE 管理 站 点 (M)… ls 
Jreamweaver 
x DAE EG) Ctrl+Shit+D 
取出 (CO) Ctri+Alt+Shift+D — lam $ 
最 近 浏 览 的 文件 HEP) Ctrl+Shift+U — Forse, e| 
FAO Ctri-Alt-Shift-U  fdate 2 
= bbslindex. php mz wm k ^ PU pun xt 
E «I» " é 显示 取出 者 (B).… de Eu 
«p bbs/content php - v 在 让 点 定位 (U) adnin php 11KB ne 
HTML CSS JS dmin login php  5KB PHP 
"b bbsibbs add.php REM.. : de 10KB PHP 
t ex 一 | reply. php 9KB PHP 
- E 站 点 特定 的 代码 提示 (S).… EOS in» fé 
小 bbs/bbs reply.php «I <I «I 同步 站 点 范围 (加 ES i: i pain 
SED.. roi 
I bbs/admin login.php E vL Es 检查 站 点 范围 的 链接 (W) Ctrl+F8 Jael_reply. php SKB PHP 
改变 站 点 范围 的 链接 (9… del_title php SKB PHP 
"i bbs/admin php |o m) y index. php esu PHP 
3 pd title. php BKB PHP 
"Y bbsidel, title.php PhoneGap Build 服务 
Z bbslupd fitle.php 站 点 设置 流体 网 格 网 站 模板 
[ n + 
K) " ' 
e, Hi...) 
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图 9-13 


3) 单 击 “ 新 建 ”按钮 ， 打 开 “ 站 点 设置 对 象 ”对 话 框 ， 


@ “站 点 名 称 ”: shopo 
e。“ 本 地 站 点 文件 夹 ” 
如 图 9-14 所 示 。 





S OOo 


KERN 
» ”高 级 设置 

















ED REAR 


: C:\xampp\htdocs\shop。 


Dreamweaver 站 点 是 网 站 中 


您 可 以 在 此 处 为 Dreamweaver 站 点 选择 本 地 文件 夹 和 名 称 。 


进行 如 下 参数 设置 。 


SHORT UE 资源 的 集合 o Dreamweaver 


et FARAS LIMER. 





站 点 名 称 : [shop 








本 地 站 点 文件 来 : | C:wamppWtdocshop\ 

















4) 单 击 列表 框 中 的 “服务 器 ”选项 ， 








立 shop 站 点 


选项 卡 ， 进 行 如 图 9-15 所 示 的 参数 设置 。 


。“ 服 务 器 名 称 ” 
o GERTE”: 
。“ 服 务 器 文件 夹 ”; 


: shop。 





本 地 /网 络 。 
C: \xampp \htdocs\。 


并 单 击 “ 添 加 服务 器 ”按钮 围 ， 打 开 
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服务 器 名 称 : [shop 
连接 方法 : | dd Pe [v 
服务 器 文件 来 : [C:Wampp\htdocs je» 
weumz[mwurosige[ —— O] 













































































图 9-15 设置 “基本 ”选项 卡 

















5) 设置 后 再 单 击 “高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 ， 单 击 “ 维 护 同 
步 信 息 ” 复 选 框 ， 在 “服务 器 模型 ”下 拉 列 表 项 中 ， 选 择 PHP MySQL 表示 是 使 用 PHP 开发 
的 网 页 ， 其 他 的 保持 默认 值 ， 如 图 9-16 所 示 。 











[VI 维护 同步 信息 

O 保存 时 自动 将 文件 上 传 到 服务 器 
O 自用 文件 取出 功能 

IV 打开 文件 之 前 取出 








取出 名 称 : 
电子 邮件 地 址 : 




















测试 服务 器 
sss [meme — ] 







































































图 9-16 设置 “高 级 ”选项 卡 




















6) 单 击 “ 保 存 ” 按 钮 ， 返 回 “ 服 务 器 ”设置 对 话 框 ， 再 单 击 选择 “测试 ” 复 选 杠 ， 
如 图 9-17 所 示 。 

单 击 “ 保 存 ” 按 钮 ， 则 完成 站 点 的 定义 设置 。 完 成 Dreamweaver CC 测试 shop 网 页 的 网 
站 环境 设置 。 





信息 。 用 PHP 开发 的 网 站 ， 
件 夹 创建 conn. php 空 




















高 级 设置 





| 连接 
本 地 


站 点 六 条 shop - 
m 您 将 在 此 位 置 选择 承载 web. 上 的 页 面 的 服务 器 。 此 计 话 杠 的 设置 来 自 
Fm Internet 服务 提供 商 (ISP) sk Web 管理 员 。 


Ron EU" 您 无 需 完成 此 步 台 。 如 果 要 连接 到 web 并 发 


mi 
RR M 


EJE 
“M 
































9-17 设置 “服务 器 ”参数 


























us 数据 库 连 接 


数据 库 设 计 之 后 ， 需 要 将 数据 库 连 接 到 网 页 上 ， 这 样 网 页 


白 页 面 ， 按 如 图 9-18 所 示 输 入 数据 库 连 


才能 调用 数据 库 和 储存 相应 


一 般 将 数据 库 连接 的 程序 代码 文件 命名 为 conn. php, TEX pe 


接 代码 。 





$ Cxampp\htdocs\shop\conn\conn.php 
K?php 
$conn-mysql connect ("localhost", "root", "" 
“数据 库 服务 器 连接 错误 " .mysql_error()); 
mysql_select_db("db_shop", $conn) or die(" 数 据 库 访 i 
mysql error()):; 
mysql query('set character set gb2312"); 
mysql query("set names gb2312"); 
?» 





) or die( 





EXEUX 


MR- 


sim. 








图 9-18 输入 数据 库 连 接 代码 
对 于 本 连接 的 程序 说 明 如 下 : 


如 果 连 接 错 误 调 用 mysql. error( ) 


< ?php 
$conn = mysql. connect( " localhost" ," root" ," admin" ) or die(" 数 据 库 服 务 右 连接 错误 ". mysql 
_error( ) ) ; 
// 设 置 数据 库 连 接 ,本 地 服务 器 ,用 户 名 为 root, 85157 admin, 
RR 


mysql. select. db( " db. shop" ,$conn) or die(" 数 据 库 访问 错误 
连接 db_shop 数据 库 , 如 果 连 接 错误 调用 mysql error( ) 。 
mysql. query( " set character set gb2312" ) ; 


x". mysql. error( ) ) ; 
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mysql_query( " set names gb2312" ) ; 
// 设 置 数据 库 的 字体 为 gb2312 即 中 文 简体 。 
?> 
读者 使 用 时 如 果 需 要 更 改 数据 库 名 称 ， 只 需要 将 该 页 面 中 的 db. shop 做 相应 的 更 改 即 可 (29) 
实现 ， 同 时 用 户 名 和 密码 和 在 本 地 安装 的 用 户 名 和 密码 要 保持 一 致 。 


网 站 首页 动态 功能 


对 于 一 个 网 站 系统 来 说 ， 需 要 一 个 主页 面 来 给 用 户 进 行 注册 、 搜 索 需 要 订购 的 商品 、 网 
上 浏览 商品 等 操作 。 实 例 的 首页 index php 主要 由 font. css, top. php, left menu. php, bot- 
tom. php 等 共 4 个 二 级 页 面 组 合 而 成 。 本 小 节 介 绍 包括 index. php 在 内 的 5 个 页 面 的 设计 。 


SL 网 站 的 样式 表 


任何 网 站 如 果 想 达到 美观 的 效果 ， 都 是 要 经 过 专业 的 网 页 布局 设计 。 实 例 按 传统 的 电子 
商务 网 站 布局 方式 进行 布局 ， 文 字样 式 的 美化 设计 是 使 用 样式 表 来 直接 设计 的 ， 实 例 的 样式 
表 保 存在 css 文件 夹 下 。 

1) 运行 Dreamweaver CC 软件 ， 打 开 制 作 到 这 一 步 的 站 点 文件 夹 。 执 行 菜单 “文件 ”一 
“新 建 ” 命 令 ， 打开 “新 建文 档 ” 对 话 杠 ， 选 择 “ 空 白 页 ”选项 卡 中 “页 面 类 型 ”下 拉 列 
表 框 中 的 CSS， 然 后 单 击 “ 创 建 ” 按 钮 创建 新 页 面 ， 如 图 9-19 所 示 。 在 网 站 css 目录 中 新 
建 一 个 名 为 font. css 的 网 页 并 保存 。 





















































页 布局 
[D zea LS 
= LESS 
In |T sess 
"Sess | Gus 
| [EC ensem | ena 
I = m 
EE 网 站 模板 = sv 
-HNL 模板 
= EWB 
T PP 模板 EBA (css) 文档 
| qua: 
| 
| 
| 
| | 
| 

















图 9-19 创建 css 文件 
2) 进入 代码 视图 窗口 ， 将 里 面 所 有 的 默认 创建 代码 删除 ， 然 后 加 入 如 下 代码 : 












QL+Dreamweaver 


A:link | 
COLOR: #006699; TEXT - DECORATION: none 
| 
A; visited | 
COLOR: #006699; TEXT ~ DECORATION: none 
| 
Al:active | 
COLOR: : #006699; TEXT ~ DECORATION: none 
| 
A:hover | 
COLOR : #000000 
| 
BODY | 
margin — top: Opx; 
| 
TD ,TH | 
FONT - SIZE:12px; COLOR: #006699 ; 
| 
// 网 页 的 链接 及 基础 属性 。 
. buttoness | 
font — family: " Tahoma" , " 宋体 " ; 
font — size; 9pt; color; 4003399; 
border; 1px #003399 solid; 
color : 006699 ; 
BORDER - BOTTOM; #93bee2 1px solid; 
BORDER - LEFT: #93bee2 1 px solid; 
BORDER - RIGHT: #93bee2 1px solid; 
BORDER - TOP: #93bee2 1px solid; 
background - color; #e8f4ff; 
CURSOR: hand; 
font — style: normal; 
| 
. inputess | 
font — size: 9pt; 
color; #003399 ; 
font — family: "宋体 " ; 
font - style; normal; 
border - color; 493BEE2 #93BEE2 #93BEE2 493BEE2 ; 
border; 1 px 493BEE2 solid; 
| 
. inputcssnull | 
font — size: 9pt; 
color; #003399; 





动态 网 站 开发 从 入 门 到 精通 
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font — family; " 宋体 " ; 
font - style: normal ; 
border; Opx 493BEE2 solid; 
| 
. scrollbar | 
SCROLLBAR - FACE - COLOR: 4FFDD22; 
FONT - SIZE: 9pt; 
SCROLLBAR - HIGHLIGHT ~ COLOR ; 4669BC2C ; 
SCROLLBAR - SHADOW - COLOR; 369BC2C; 
SCROLLBAR -3DLIGHT ~ COLOR ; 469 BC2C ; 
SCROLLBAR - ARROW - COLOR ; zHfffff; 
SCROLLBAR -TRACK - COLOR ; #69BC2C; 
SCROLLBAR ~ DARKSHADOW - COLOR ; #69BC2C 


| 

. scrollbar | 
SCROLLBAR - FACE - COLOR: 4FFDD22; 
FONT - SIZE: 9pt; 
SCROLLBAR - HIGHLIGHT ~ COLOR; 469BC2C ; 
SCROLLBAR - SHADOW - COLOR: 469BC2C ; 
SCROLLBAR -3DLIGHT ~ COLOR; 3469 BC2C; 
SCROLLBAR - ARROW - COLOR : #ffffff; 
SCROLLBAR -TRACK - COLOR: #69BC2C; 
SCROLLBAR - DARKSHADOW - COLOR : 469BC2C 


| 
// 网 页 表单 对 象 的 样式 设置 


通过 上 面 样式 文件 的 建立 ， 可 以 将 整个 网 站 的 样式 统一 ， 起 到 美化 整个 网 站 的 效果 。 


| 建立 导航 ) 


导航 频道 是 网 站 建设 中 很 重要 的 部 分 ， 通 常情 况 下 ， 一 个 网 站 的 页 面 会 有 几 十 个 ， 更 大 
型 一 点 的 可 能 会 达到 几 千 个 甚至 几 万 个 ， 每 个 页 面 都 会 有 导航 栏 。 但 是 ， 在 网 站 后 期 维护 或 
者 需要 更 改 的 时 候 ， 这 个 工作 量 就 会 变 得 很 大 。 所 以 为 了 方便 ， 通 常 都 会 把 导航 栏 开 发 成 单 
独 的 一 个 页 面 ， 然 后 让 每 个 页 面 都 单独 调用 它 。 这 样 当 需要 变更 的 时 候 ， 只 要 修改 导航 栏 这 
一 个 页 面 ， 其 他 的 页 面 自动 就 被 更 新 了 。 实 例 创建 的 带 搜索 功能 的 导航 频道 ， 如 图 9-20 
所 示 。 

这 里 制作 的 步骤 如 下 。 

1) 在 Dreamweaver CC 中 执行 菜单 “文件 ”一 “新 建 ” 命 令 , 打开 “新 建文 档 ” 对 话 
框 ， 选 择 “ 空 白 页 ”选项 卡 中 “页 面 类 型 ”下 拉 列 表 框 中 的 PHP 选项 ， 在 “布局 ”下 拉 列 
表 框 中 选择 “无 ”选项 ， 然 后 单 击 “创建 ”按钮 创建 新 页 面 ， 在 网 站 根 目 录 下 新 建 一 个 名 
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OM ~ E] http://127.0.0.1/shop/top.php Eo-nex| QIE 
电子 商务 网 站 x 


PHP 电 子 商务 网 站 


首 页 | 最 新 上 架 | 推荐 产品 | 热门 产品 | 产品 分 类 | 用 户 中 心 | 订单 查询 | 购物 车 




















图 9-20 搜索 导航 频道 


为 top. php 的 网 页 并 保存 。 
2) 再 单 击 “ 显 示人 代码 视图 ”选择 加 fj 各 按钮 ， 进 入 代码 视图 窗口 ， 将 里 面 所 有 的 默认 
创建 代码 删除 ， 然 后 加 入 如 下 代码 ; 


<html > 





<head > 
< meta http ~ equiv = " Content ~ Type" content = " text/html; charset = gb2312" > 
< title > 电子 商务 网 站 < /title > 
< link rel = " stylesheet" type = " text/css" href = "css/font. css" > 
</head > 
« body > 
«table width 2 "766" border = "0" align =" center" cellpadding = "0" cellspacing 2 "0" background 
="images/ bannerdi. gif" > 
« tbody > 
<tr> 
< td width = "231" height 2 "85" > &nbsp; </td > 
< td width = "535" align =" left" > < p > &nbsp; </p> 
«p» &nbsp; </p> 

<p> <a href =" index. php" > 首 页 </a>| <a href 2 "shownewpr. php" > ijt EŻ </a> | 
<a href 2 " showtuijian. php" > 推荐 产品 </a > | <a href =" showhot. php" > 热门 产品 </a > | &nbsp; 
<a href = " showfenlei. php" > 产品 分 类 </a > | &nbsp; < a href =" usercenter. php" > 用户 中 心 
</a> |&nbsp; « a href = " finddd. php" > 订单 查询 </a > | &nbsp; <a href = " gouwuche. php" > 购 
WE </a> </p> </td> 

















</tr> 
< /tbody > 
</table > 
最 后 保存 制作 的 页 面 ， 按 下 (F12) 快捷 键 ， 即 可 以 在 正 浏 览 器 中 看 到 和 原来 一 样 的 


导航 效果 。 


" 层 十 出 | 登录、 新 闻 及 搜索 


在 index. php 页 面 中 的 “产品 信息 ”栏目 里 面 ， 如 果 不 加 入 动态 功能 ， 则 只 能 显示 原来 
设计 的 静态 文字 。 如 果 想 调用 建立 的 shop 数据 库 中 “新 闻 表 ”里 面 的 新 闻 数 据 ， 并 且 能 
显示 最 新 的 10 条 信息 ， 如 何 用 PHP 进行 连接 和 处 理 呢 ? 














下 面 就 详细 介绍 该 功能 的 开发 办 法 ， 制 作 步 又 如 下 。 
1) 为 了 能 够 实现 页 面 的 调用 ， 需 要 首先 打开 数据 库 db. shop 文件 ， 然 后 再 打开 tb_ 
gonggao 数据 表 ， 加 入 一 些 数 据 ， 如 图 9-21 所 示 。 
IEEE e 
让 | 个 人 - | 4h http://127.0.0.1/phpmyadmin/SPMAURL-2:sgl.php?db- db shop&table-tb gonggao&server-l&target-&token X O- X| D yy (9) 


A 127.0.0.1 / 127.0.0.1 / db... X 
phpMuadm in ARZE: 127.0.0.1 > © 数据 库 : db_shop » I Æ: tb_gonggao 
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图 9-21 加 入 数据 











2) J£ left menu. php 页 面 ， 然 后 在 < head > 代码 之 前 ， 加 入 调用 数据 库 链 接 页 面 
conn. php 的 命令 ， 如 下 : 


< ?php include( " Conn/conn. php" ) ;? > 


我 的 购物 车 主要 实现 登录 后 能 显示 登录 的 用 户 名 ， 并 显示 购物 车 的 实时 情况 ， 实 现 的 
PHP 代码 如 下 : 


«table width = "209" border ="0" cellspacing = "0" cellpadding = "0" > 
«tir» 








<td > <img src = " images/carttop. jpg" width = "209" height 2 "46" /> </td> 
</tr> 
«tir» 
<td> 
<table width = "100% " border 2 "0" cellspacing = "0" cellpadding = "0" > 
«tir» 
<td > <font color = " #FF3300" > 
&nbsp; &nbsp; < ?php 
if($. SESSION[ username | !="" ) | 
echo " fH P! :$. SESSION[ username ] ,欢迎 您 1" ; 
| 
else 


{echo " 用户 :游客 ,欢迎 您 ! <br > &nbsp;&nbsp; 请 先 登 录 ,后 购物 " ; | 
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?> 

</font> </td> 
</tr> 

<tr> 

<td> 


<table width = "209" border 2 "0" align = "center" cellpadding = "0" cellspacing 2 "0" > 


< form action = " gouwuche. php" method = " post" name = " form1" id =" form1" > 
«tir» 


<td> 
< ?php 
//session_register( " total" ) ; 
if($ GET[ qk] 22" yes") | 
$ SESSION[| producelist] = "" ; 
$ SESSION[| quatity] 2" " ; 


Sarraygwe = explode( "  " ,$ SESSION[ producelist | ) ; 
$s 20; 


for($i 20;$i < count($arraygwe) ;$i ++ ) | 
$s += intval($arraygwe[$i ] ) ; 
| 
if($s ==0) | 
echo " <tr>"; 


echo" &nbsp;&nbsp; 您 的 购物 车 为 空 !" ; 
echo" </tr>"; 


| 


else | 
7» 

« ?php 

$total 20; 

$array = explode(" 9 " ,$ SESSION[ producelist ] ) ; 
Sarrayquatity = explode( " @ " ,$ SESSION[ quatity ] ) ; 

while( list($name,$value) = each($. POST) ) | 
for($i 20;$i < count($array) —1;$i ++ ) | 
if( (Sarray[$1] ) 22 $name) | 
Sarrayquatity[$1] =$value; 


| 
$_SESSION[ quatity] = implode( " @ " , $arrayquatity ) ; 


for($i 20;$i < count($array) —1;$i ++) | 
$id = $array[$i ] ; 
$num = $arrayquatity [$i ] ; 
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if($id!="")] 
$sql = mysql. query (" select * from tb_shangpin where id = ". $ 


id. " " ,$conn) ; G 
$info = mysql. fetch. array ($sql) ; 


$totall 2 $num *$info[ huiyuanjia ] ; 
$total += $totall ; 
$, SESSION[| "total" ] 2$total ; 


7» 
&nbsp; 
< ?php 
| 
| 
7» 
购物 车 总 计 : < ?php echoS$total; ? > 元 


<br> 
&nbsp; &nbsp; < a href =" gouwusuan. php" > 去 收银 台 </a > <a href =" gou- 
wuche. php?qk = yes" > 清空 购物 车 </a> 
< ?php 
| 
7» 
« ?php 
if($. SESSION[ username | !="" ) | 
echo " &nbsp; &nbsp; <a href + logout. php. > 注销 离开 </a>"; 


| 
?> </br> 
</td> 
</tr> 
«/form > 
</table > 


然后 简单 地 设计 一 下 功能 的 显示 效果 ， 设 计 完 成 后 编辑 文档 窗口 ， 如 图 9-22 所 示 。 








El cxampp\htdocs\shop\left_menu.php -0x 
CASP conn. php 
B E EH 388 x 126v 




















9-22 设计 购物 车 


3) 在 “用 户 系统 ”的 显示 界面 上 ， 给 用 户 提供 了 登录 、 注 册 以 及 找 回 密码 的 功能 ， 具 
体 的 注册 和 找 回 密码 的 功能 将 在 下 一 节 介 绍 ， 这 里 重点 介绍 使 用 PHP 实现 验证 码 随 机 调用 









PHP-*MySQL t Dreamweaver 动态 网 站 开发 从 入 门 到 精通 





并 显示 为 数字 的 功能 程序 如 下 : 











<?php 
$num = intval( mt, rand(1000,9999) ) ; 

// 使 用 到 了 mt. rand) 函数 调用 介 于 1000 ~ 9999 的 任意 一 个 数字 。 
for($i=0;$i<4;$i++ )| 


























echo 


} 
// 调 用 images/codev 文 件 夹 下 的 随机 字母 图 片 ,并 显示 成 4 位 数 。 


7» 


该 程序 能 够 实现 如 图 9-23 所 示 的 随机 显示 图 片 验证 码 数字 的 效果 。 


<img src = images/code/" . substr( strval($num) ,$i,1). ". gif >"; 





























验 WE: 203 


zm 找 回 密码 














图 9-23 显示 验证 码 效 果 


4) 用 户 输入 用 户 名 和 密码 ， 并 单 击 “ 提 交 ” 按 钮 后 ， 要 将 输入 的 数据 传递 到 chkus- 

er. php 页 面 进行 登录 验证 。 代 码 如 下 : 
< form name =" form2" method =" post" action =" chkuser. php" onSubmit = " return chkuserinput 
(this)" » 

该 段 代 码 包 含 了 两 个 意思 ， 第 一 个 action =" chkuser. php" 意思 是 转 到 chkuser. php 页 面 
进行 验证 ;第 二 个 onSubmit = " return. chkuserinput( this) "意思 是 直接 调用 JavaScript 的 chku- 
serinput( this) 进行 数据 输入 的 验证 ， 即 通常 在 提交 表单 时 ， 要 验证 一 下 输入 的 数据 是 否 为 
空 ， 输 入 的 数据 格式 是 否 符合 要 求 ， 调 用 的 程序 如 下 : 





< script language = " javascript" > 
function chkuserinput( form ) | 
if( form. username. value 22 "" ) | 
alert ( 1848 A FH P4 1" ) ; 
form. username. select( ) ; 
return( false) ; 
| 
// 如 果 用 户 名 没 输入 , 则 提示 “请 输入 用 户 名 !” 
if( form. userpwd. value 22 "")| 
alert(" 请 输入 用 户 密码 1" ) ; 


form. userpwd. select( ) ; 











return( false) ; 


1 
j 


A/ 如果 用 户 密码 没 输入 , 则 提示 “请 输入 用 户 密码 !1” 





























CHE 





if( form. yz. value 22 "") | 
alert(" 请 输入 验证 码 1" ) ; 


form. yz. select( ) ; 


return( false) ; 
D E 


A/ 如 果 用 户 验证 码 没 有 输入 , 则 提示 “请 输入 验证 码 1” 


return( true ) ; 





«/script > 


5) 在 主页 的 “行业 新 闻 ” 显 示 的 数据 要 实现 的 效果 是 调 出 新 闻 的 标题 ， 在 单 击 标题 时 
能 打开 详细 页 面 ， 调 出 5 条 数据 。 下 面 将 所 有 的 代码 列 出 。 


< ?php 

$sql = mysql. query (" select * from tb. gonggao order by time desc limit 0,5" ,$conn); 
// 按 时 间 顺 序 从 tb. gonggao 数据 表 中 调用 5 条 数据 

$info = mysql_fetch_array($sql ) ; 

if($info ==false) | 


7» 

















«tir» 
<td height 2 "20" align =" center" > 暂 无 新 闻 公 告 ! </td> 
</tr> 
// 如 果 没 有 数据 则 显示 为 “ 暂 无 新 闻 公 告 1” 
< ?php 
| 
else | 
dof 
?> 
«tir» 
< td height = "20" > < div align = " center" > 
< table width = "180" border 2"O" align =" center" cellpadding = "0" cellspacing = "0" > 
«tr» 
<td width 2" 16" height 2 "5" > < div align =" center" > < img src =" images/circle. gif" width = 
"11" height 2" I2" > </div> </td> 
<td width = "164" height 2 "24" > «div align =" left" > <a href = " gonggao. php?id =< ?php echo 
$info[ id] ;? >" > 
< ?php 
echo substr($info[ title] ,0,24) ; 
if( strlen(Sinfo[ title] ) >24) | 
echo "+e"; 
1 7/ 调用 新 闻 标 题 并 控制 显示 的 字符 数 为 24 ,如 果 标 题 比较 长 则 显示 为 … 


7» 











</a> </div> </td> 
</tr> 
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</table > 

</div> </td> 

</tr> 

< ?php 

| 

while( $info = mysql_fetch_array ($sql) ) ; 
| 


7» 
6) 在 浏览 器 中 浏览 到 制作 的 调用 数据 的 结果 ， 具 体 效 果 如 图 9-24 所 示 。 
行业 新 闻 : 更 多 


» 理性 选择 原装 耗材 或 通用 耗材 
» 我 国 纸 业 三 大 热点 值得 关注 
» 用 办 公文 具 组 装 星 战 模型 
» 加 强 出 口 铅笔 检验 监管 
»》” 中 国 优 夏 产品 认证 启动 
»》” 欧 盟 纳米 材料 法 规 的 最 新 进展 





(uu 


图 9-24 "ib BC 








Wi BÀ: 

如 此 轻易 就 实现 了 数据 库 的 调用 、 查 询 以 及 显示 操作 ， 读 者 会 发 现 PHP 动态 网 页 的 开 
发 并 不 是 很 难 ， 只 需要 掌握 简单 的 代码 即 可 以 实现 。 在 下 面 的 所 有 其 他 功能 区 域 都 是 采用 调 
用 、 条 件 查询 、 绑 定 显示 、 关 闭 数据 库 这 样 一 个 相同 的 操作 步骤 来 实现 的 。 

7) 最 下 面 的 “站 内 搜索 ”功能 开发 是 将 查询 文本 框 放 置 到 一 个 表单 内 ， 在 单 击 “ 搜 
索 ” 时 提交 到 serchorder. php 页 面 进行 搜索 并 显示 结果 页 面 ， 单 击 “ 高 级 ”按钮 时 提交 到 
highsearch. php 页 面 进行 高 级 的 搜索 ， 该 程序 主要 航 和 在 <form > 表单 之 内 ， 代 码 如 下 : 





< form name = "form" method = " post" action = " serchorder. php" > 

«tr» 
<td width = "500" height = "30" valign =" middle" > < div align = " center" > 
«input type = "text" name =" name" size 2 "15" class =" inputess" style = " background - color ; #fff " 
onMouseOver = " this. style. backgroundColor = sffffff " onMouseOut = " this. style. backgroundColor = 
Se8fAIf " > 


< input type = " hidden" name = "jdez" value = "jdez" > 

< input name = " submit" type = " submit" class = " buttoncss" value = " Ez" > 

<input name = " button" type =" button" class = " buttoness" onClick = " javascript ; window. location = 
' highsearch. php ;" value =" S" > 

</div> </td> 

</tr> 


«/form > 


此 时 left_meau. php R MAI RRR A56 86 T, WEAD ERREEN, 
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,产品 的 动态 展示 


网 站 实现 在 线 购物 ， 一 般 都 是 通过 用 户 自身 登录 、 浏 览 、 订 购 、 结 算 这 样 的 流程 来 实现 
的 ， 所 以 在 首页 上 制作 产品 的 动态 展示 功能 非常 重要 。 实 例 在 首页 上 设计 了 “推荐 产品 ”、 
“最 新 上 架 ” 以 及 “热门 产品 ”3 个 显示 区 域 ， 下 面 就 介绍 产品 展示 区 域 的 实现 方法 。 

1) 对 于 上 述 的 3 个 显示 区 域 ， 在 使 用 程序 开发 之 前 ， 首 先 要 在 Dreamweaver CC 中 设计 
好 最 终 的 网 页 效果 。 实 例 设计 的 3 个 展示 区 域 如 图 9-25 所 示 ， 每 个 区 域 显 示 最 新 发 布 的 两 
款 产 品 信息 ， 将 产品 的 图 片 、 价 格 、 数 量 全 部 展示 出 来 ， 并 加 入 “购买 ”和 显示 “详细 ” 
的 按钮 。 
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图 9-25 设计 产品 展示 的 区 域 效果 


2) 3 个 区 域 的 程序 实现 的 方法 是 一 样 的 ， 只 是 按 条 件 查询 出 的 数据 结果 不 一 样 。 这 里 
介绍 “推荐 产品 ”区 域 的 代码 实现 方法 如 下 : 


«table width = "550" border ="00" align = "center" cellpadding = "0" cellspacing = "0" > 





<tr> 
<td width = "555" height 2" 110" > «table width = "530" height 2 "110" border = "0" align = " cen- 
ter" cellpadding 2 "0" cellspacing = "0" > 
«tir» 
<td width = "265" > 
< ?php 
$sql = mysql_query ( " select * from tb_shangpin where tuijian = 1 order by addtime desc limit 0, 
1") ;// 按 tuijian =1 的 值 调用 数据 
$info = mysql. fetch. array ($sql) ; 
if( $info == false) | 
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1 如 果 没 有 数据 , 则 显示 为 "本 站 和 暂 无 推荐 商品 ! 

else | 

7» 

< table width = "270" border ="0" cellspacing = "0" cellpadding = "0" > 
<tr> 


<td width = "130" rowspan 2 "5" > « div align =" center" > 


< ?php 
if(trim($info[ tupian] =="")) | 
echo "和 暂 无 图 片 " ; 
| /如果 没有 产品 图 片 , 则 显示 为 " 暂 无 图 片 ， 
else| 
7» 


<img src =" < ?php echo $info[ tupian] ;? >" width = "80" height = "80" border = "0" > 
< ?php 
| 

7» 
</div> </td> 
<td width = "11" height 2 "16" > &nbsp; «/td > 
<td width = "124" > «font color = " FF6501" > < img src = " images/circle. gif" width = "10" height 
="10" > &nbsp; <?php echoS$info[ mingcheng] ;? > «/font > </td > 
</tr> 
<tr> 
<td height 2" 16" > &nbsp; </td > 
<td> «font color = " #000000" > 市场 价 . «/font > < font color = " FF6501" > < ? php echo $ info 
[shichangjia];?» «/fon > </td> 





</tr> 
<tr> 
<td height 2" 16" > &nbsp; </td > 
<td> «font color = " #000000" > 会 员 价 : </font > < font color 2 " FF6501" > < ? php echo $ info 
[huiyuanjia] ;? > </font> </td> 
</tr> 
<tr> 
<td height = "16" > &nbsp; </td > 
<td> <font color = " #000000" > 剩余 数量 ; </font> «font color 2"13589B" > < ?php 
if($info[ shuliang] >0) 
| 
echo $info[ shuliang ] ; 
| 


else 


| 


echo "已 售 完 "; 
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7» 
</font> </td> 
</tr> 
<tr> 
<td height = "30" colspan ="2" > <a href = " lookinfo. php?id =< ?php echo $info[ id] ;? >" > <img 
src = "images/b3. gif" width =" 34" height 2" 15" border ="0" > </a > <a href =" addgou- 





wuche. php?id =< ?php echo $info[ id];? >" > <img src = " images/bl. gif" width = "50" height = 
"15" border 2 "0" > </a> </td> 
</tr> 
« /table > 
« ?php 
| 
?> 
</td> 
«td width = "265" > 
< ?php 
$sql = mysql_query (" select * from tb_shangpin where tuijian = 1 order by addtime desc limit 1,1") ; 
$info = mysql. fetch. array ($sql) ; 
if( $info == true) 
| 
?> 
«table width 2"270" border = "0" cellspacing ="0" cellpadding = "0" > 
«tr» 
<td width = " 130" rowspan = "5" > < div align = " center" > 
« ?php 
if( trim(Sinfo[ tupian] 22 ""))| 
echo" 暂 无 图 片 " ; 
| 
else| 
7» 
< img sre =" < ?php echoSinfo[ tupian] ;? >" width 2 "80" height 2 "80" border = "0" > 
« ?php 
| 
7» 
</div> </td> 
<td width = "11" height 2 "16" > &nbsp; «/td > 
<td width = "124" > «font color = " FF6501" > < img src = " images/circle. gif" width = " 10" height 
="10" > &nbsp; <?php echoS$info[ mingcheng] ;? > «/font > </td > 
</tr> 
<tr> 
<td height = "16" > &nbsp; </td > 
<td> «font color = " #000000" > 市场 价 . «/font > < font color = " FF6501" > < ? php echo $ info 
[shichangjia];?» </font > </td> 
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</tr> 
<tr> 
<td height 2" 16" > &nbsp; </td > 
<td> «font color = " #000000" > Z fi ffr; «/font > < font color = " FF6501" > < ? php echo $ info 
[ huiyuanjia];? > </font> </td> 
</tr> 
<t> 
<td height 2" 16" > &nbsp; </td > 
<td> <font color = " #000000" > 剩余 数量 ; < /font > «font color 2" 13589B" > 
< ?php 
if($info[ shuliang] >0) 
| 
echo $info[ shuliang ] ; 
| 
else 
| 
echo "已 售 完 "; 
| 
?> 
</font > </td > 
</tr> 
«tir» 
<td height = "30" colspan 2 "2" > «a href = " lookinfo. php?id =< ?php echo$infol id] ;? >" > <img 
src = "images/b3. gif" width =" 34" height 2" 15" border =" 0" > </a > «a href =" addgou- 
wuche. php?id =< ?php echo $info[ id];? >" > «img sre = " images/bl. gif" width = " 50" height = 
"15" border = "0" > </a> </td> 
</tr> 
« /table > 
« ?php 
| 
7» 
</td> 
</tr> 
</table > «/td > 
</tr> 
«tir» 
<td height 2" 10" background = " images/linel. gif" > </td > 
</tr> 
« /table > 


3) 按 上 述 的 程序 实现 方法 ， 将 另外 两 个 产品 展示 的 功能 设计 完成 ， 最 后 可 以 实现 的 效 
果 如 图 9-26 所 示 。 





站 开发 从 入 门 到 精通 
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四 ASA. ~ E] http://127.0.0.1/shop/ $29 0o-Box| ii 














GmTESP x unn 
密 码 : 


会 员 价 : 100 
剩余 数量 : 10 
[| [» 购买 


» 兄弟 标签 打印 机 色 带 
市 场 价 : 155 
会 员 价 : 105 > 
剩余 数量 : 10 ENS 剩余 数量 : 10 
EZALE] ` m [» Wax] 


» 兄弟 标签 打印 机 色 带 » 办 公 旧 -0 
市 场 价 : 155 00 
会 员 价 : 105 00 
剩余 数量 : 10 | RAE: 
EZALE] E) [» Wc] 


图 9-26 首页 的 商品 展示 效果 


JSS 底部 版 权 页 面 


底部 版 权 页 面 是 一 个 静态 的 页 面 ， 制 作 非 党 简单 。 在 Dreamweaver CC 中 进行 直接 排版 
设计 即 可 ， 完 成 的 效果 如 图 9-27 所 示 。 
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图 9-27 版 权 页 面 的 设计 效果 
以 上 网 站 的 首页 制作 全 部 结束 ， 如 果 需 要 快速 建立 首页 ， 可 以 直接 参考 附 赠 资 源 中 完成 
的 页 面 ， 查 看 代码 ， 可 以 方便 地 完成 网 上 购物 系统 首页 的 设计 与 制作 。 


4^ rr Zr ^b 
会 员 系 统 功能 


网 站 的 会 员 系 统 的 首页 可 以 让 用 户 完成 登录 或 注册 。 当 输入 用 户 名 和 密码 后 ， 单 击 
“提交 ”按钮 ， 即 转 到 chkuser php 页 面 进行 判断 是 否 成 功 登 录 。 当 单 击 “注册 ”文字 链接 
时 ， 将 会 打开 网 站 的 会 员 注册 页 面 agreereg. php 进行 注册 。 单 击 “ 找 回 密码 ”会 弹出 找 回 密 
1358 Windows 对 话 窗 口 。 下 面 就 介绍 会 员 系 统 的 开发 方法 。 


















QL*Dreamweaver 动态 网 站 开发 从 入 门 到 精通 


SUP 会 员 登 录 判 断 


会 员 在 首页 输入 用 户 名 和 密码 后 ， 单 击 “ 提 交 ” 按 钮 ， 只 有 用 户 名 、 密 码 、 验 证 码 全 
如 果 发 生 错误 就 需要 显示 相关 的 错误 信息 ， 所 有 的 功能 都 要 用 PHP 
行 分 析 判 断 。 创 建 一 个 空白 PHP 页面， 并 命名 为 chkuser. php。 
在 该 页 面 中 加 入 如 下 的 代码 : 
< ?php 
include( " conn/conn. php" ) ;// 调 用 数据 库 连 接 
$username - $, POST[ username | ; 
Suserpwd = md5($. POST[ userpwd | ) ; 
$yz 2$. POST| yz]; 
$num 2$. POST| num] ; 
if( strval($8yz) != strval($num) ) | 
echo " < script > alert 验证 码 输入 错误 ! ) ; history. go( 71) ; </script>"; 
exit ; 
1 如 果 验 证 码 错误 , 则 提示 “验证 码 输 入 错误 !”, 并 且 返 回 登录 页 面 


class chkinput | 











var $name; 
var $pwd; 
function chkinput( $x, $y) | 
$this -> name = $x; 
$this -> pwd = $y; 
| 
function checkinput( ) | 
include( " conn/conn. php" ) ; 
$sql = mysql. query ("select * from tb, user where name = ". $this -> name. " " , $conn) ; 
$info = mysql. fetch array ($sql) ; 
if( $info == false) | 
echo " < script language + javascript > alert | 不 存在 此 用 户 ! ) ; history. back ( ) ; 
</script>"; 
exit; 
上/ 如果 数据 库 里 不 存在 该 用 户 名 , 则 显示 “不 存在 此 用 户 ”, 并 返回 
else| 
if($info[ dongjie] 221) | 
echo " < script language + javascript > alert ( 该 用 户 已 经 被 冻结 ! ) ; histo- 
ry. back() ; </script>"; 





exit ; 
1 如 果 用 户 已 经 在 后 台 被 冻结 , 则 显示 “该 用 户 已 经 被 冻结 !”, 并 返回 
if($info[ pwd] == $this -> pwd) 
| 


session, start( ) ; 
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$_SESSION[ username | = $info[ name] ; 
session register( " producelist" ) ; 


"n", 
, 


$producelist = 


session register( " quatity" ) ; C» 
$quatity Z"" ; 


header( " location :index. php" ) ; 





exit; 
| 
else | 
echo " < script language + javascript > alert( 密码 输入 错误 I" ) ; history. back ( ) ; 
</script>"; 
exit; 


1 如 果 用 户 密码 错误 , 则 显示 ”密码 输入 错误 !”, 并 返回 








$obj = new chkinput( trim($username) ,trim($userpwd) ) ; 
$obj -> checkinput( ) ; 
7» 


该 段 程 序 ， 首 先 判断 验证 码 、 用 户 名 以 及 密码 是 否 是 正确 的 代码 ， 如 果 不 正 确 ， 则 显示 
相应 的 错误 信息 ; 如 果 全 部 正确 ， 则 登录 成 功 并 返回 登录 的 首页 。 


9.4.2 


会 员 注 册 功 能 并 不 只 是 简单 的 一 个 网 页 就 能 实现 ， 它 需要 同意 协议 以 及 判断 用 户 是 否 已 
存在 ， 写 人 数据 等 细节 步 又 如 下 。 

1) 单 击 “注册 ”文字 链接 时 ， 将 会 打开 网 站 的 会 员 注 册页 面 agreereg. php, ， 该 页 面 制 
作 的 效果 如 图 9-28 所 示 。 该 页 面 的 内 容 是 必 不 可 少 的 ， 提 示 给 网 站 管理 员 ， 为 避免 日 后 与 
注册 用 户 发 生 纠纷 ， 需 要 提前 将 网 站 所 提供 的 具体 服务 和 约束 等 内 容 ， 放 到 注册 信息 里 面 ， 
这 样 可 以 有 效 地 保护 自己 的 利益 。 

2) 单 击 “ 同 意 ” 按 钮 后 ， 就 打开 具体 的 注册 用 户 信息 填写 内 容 页 。 该 页 面 制作 也 比较 
简单 ， 只 需要 以 数据 库 中 tb. user 数据 表 的 字段 名 为 准 ， 在 注册 页 面 分 别 创建 相应 的 文本 框 
即 可 ， 如 图 9-29 所 示 。 

3) 其 中 的 技术 难点 在 于 “查看 昵称 是 否 已 用 ”功能 ， 在 输入 用 户 昵 称 时 ， 需 要 单 击 该 
按钮 ， 检 查 数 据 库 中 是 否 已 存在 该 用 户 昵称 。 实 现 的 方法 代码 如 下 : 











< script language =" JavasCript" > 
function chknc( nc ) 
| 


windows. open( " chkusernc. php?nc =" + nc," newframe" ," width = 200, height = 10 , left = 500 , top = 











200 , menubar = no , toolbar = no , location = no, scrollbars = no location = no" ) ; 








1 单独 打开 Windows 窗口 通过 调用 chkuserne. php 页 面 进行 判断 

















</script > 
TÈ cwampp\htdocs\shop\agreereg.php El 
(XU topphp left menu php bottom. php hd 


RASSIEDTEUENERPEETAXET. 


























J> 


B E EH 758 x 451v 





























图 9-28 同意 网 站 里 的 服务 条 款 





TÈ cwampp\htdocs\shop\reg.php -0x 





CRE top.php bottom. php 


pp 


m 








] D 


[>> body B D EH 758 x 451v 
































图 9-29 用 户 填写 注册 信息 的 页 面 


所 以 内 套 的 实际 判断 页 面 是 chkusernc. php, ， 该 页 面 的 代码 如 下 : 


< ?php 

$nc - trin($. GET[ nc]) ; 
?> 

< ?php 

include( " conn/conn. php" ) ; 


7» 








ILL 【PHP 网 上 购物 系统 前 台 





<html > 

« head > 

« title > 

昵称 重用 检测 S 


«/title > 








< link rel = " stylesheet" type = " text/css" href = " css/font. css" > 
</head > 
< body topmargin = "0" leftmargin 2 "0" bottommargin = "0" > 
< table width = "200" height =" 100" border = "0" align = " center" cellpadding = "0" cellspacing = 
"0" bgcolor = " #eeeeee" > 
«tr» 
<td height = "50" > <div align = " center" > 
< ?php 
if($nc =="") 
| 
echo " 请 输入 昵称 1" ; 
| 
else 
| 
$sql =mysql_query( " select * from tb, user where name = ". $nc. " " ,$conn) ; 
$info = mysql. fetch array ($sql) ; 
if( $info == true) 
| 
echo " 对 不 起 ,该 昵称 已 被 占用 1"，; 
| 
else 
| 
echo "恭喜 ,该 昵称 没 被 占用 !" ; 


7» 
</div> </td> 
</tr> 
«tr» 
< td height = "50" > < div align = " center" > < input type =" button" value =" 确 定 " class = 
"buttoncss" onClick = " window. close( )" > «/div» </td > 
«/tr» 
« /table > 
« / body > 


4) 在 单 击 “ 提 交 ” 按 钮 时 ， 还 要 实现 所 有 的 字段 检查 功能 ， 调 用 JavaScript 程序 进行 
检查 的 代码 如 下 : 


< script language =" JavaScript" > 
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function chkinput( form) 
| 
if( form. usernc. value == "" ) 
| 
alert(" 请 输入 昵称 1" ); 
form. usernc. select( ) ; 
return( false) ; 
| 
if( form. pl. value =="") 
| 
alert(" 请 输入 注册 密码 1" ) ; 
form. pl. select( ) ; 





return( false) ; 
| 
if( form. p2. value =="") 
| 
alert(" 请 输入 确认 密码 1" ) ; 
form. p2. select( ) ; 
return( false) ; 
| 
if( form. pl. value. length «6) 
| 
alert(" 注册 密码 长 度 应 大 于 61" ); 


form. pl. select( ) ; 





return( false) ; 
| 
if( form. pl. value != form. p2. value) 
| 
alert(" 密码 与 重复 密码 不 同 !" ) ; 
form. pl. select( ) ; 
return( false) ; 
| 
if( form. email. value == "") 
| 
alert(" 请 输入 电子 邮箱 地 址 1" ) ; 
form. email. select( ) ; 
return( false) ; 
| 
if( form. email. value. indexOf( € ) <0) 
| 
alert(" 请 输入 正确 的 电子 邮箱 地 址 1" ) ; 


form. email. select( ) ; 





return( false) ; 





| QE ES ES 


if( form. tel. value == "") 
| 
alert(" 请 输入 联系 电话 1" ) ; 
form. tel. select( ) ; 
return( false) ; 
| 
if( form. truename. value == "") 
| 
alert(" 请 输入 真实 姓名 1" ) ; 


form. truename. select( ) ; 








return( false) ; 
| 
if( form. sfzh. value == "") 
| 
alert(" 请 输入 身份 证 号 1" ); 
form. sfzh. select( ) ; 
return( false) ; 
| 
if( form. dizhi. value =="") 
| 
alert(" 请 输入 家 庭 住 址 1" ) ; 
form. dizhi. select( ) ; 
return( false) ; 
| 
if( form. tsda. value == "") 
| 
alert(" 请 输 密 码 提示 答案 !" ) ; 
form. tsda. select( ) ; 
return( false) ; 
| 
if( (form. tsl. value 221) &&( form. ts2. value=="")) 
| 
alert(" 请 选择 或 输入 密码 提示 答案 1" ) ; 
form. ts2. select( ) ; 
return( false) ; 
| 
return( true ) ; 
| 


</script > 


该 段 程序 是 验证 表单 时 经 常 使 用 的 方法 ， 读 者 可 以 重点 浏览 并 掌握 其 功能 ， 在 其 他 系统 
的 开发 中 也 经 常 被 使 用 到 。 
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5) 在 验证 表单 没 问 题 后 ， 才 将 表单 的 数据 传递 到 savereg. php. 页 面 进行 数据 表 的 插入 记 
录 操 作 ， 也 就 是 实质 上 的 保存 用 户 注册 信息 的 操作 。 有 具体 的 代码 如 下 : 


< ?php 
session, start( ) ; 
include( " conn/conn. php" ) ; 
$name - $. POST[| usernc ] ; 
$pwdl 2$ POST[pl]; 
$pwd = md5($ POST|[ pl ] ) ; 
$email 2$, POST[ email ] ; 
$truename 2$. POST| truename] ; 
$sfzh 2$. POST[ sfzh ] ; 
$tel 2$. POST[ tel] ; 
$qq =$_POST[ qq] ; 
if($ POST[ts1] 221) 
| 
$tishi 2$, POST[ts2] ; 
| 
else 
| 
$tishi -$ POST[ts1] ; 
| 
$huida 2$. POST[ tsda | ; 
$dizhi 2 $, POST[ dizhi ] ; 
$youbian 2$. POST[ yb]; 
$regtime = date(" Y -m -j" ) ; 
$dongjie 20; 
$sql = mysql. query ( " select * from tb, user where name = ". $name. " " ,$conn) ; 
$info = mysql. fetch array ($sql) ; 
if( $info == true) 
| 
echo " < script > alert( 该 昵称 已 经 存在 !" ) ;history. back( ) ; </script>"; 
exit; 
| 
else 
| 
mysql_query( " insert into tb. user ( name , pwd , dongjie , email , truename , sfzh , tel , qq ,tishi, huida, 
dizhi , youbian , regtime, pwdl) values ( $namé ', $pwd ', $dongjié ', $email ', $truenamé ', $sfzh ', $tel , 
' $qq ', $tishi ', $huidå ', $dizhi ', $youbian ', $regtimé ', $pwd1 )" ,$conn) ;// 按 字段 对 应 相应 的 数据 
session register( " username" ) ; 
$username = $name; 
session register( " producelist" ) ; 


"n", 
, 


$producelist = 
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session register( " quatity" ) ; 


$quatity 2"" ; 
echo " < script > alert( 恭喜 ,注册 成 功 ! ) ; window. location + index. php ; </script>" ; 
1 插入 数据 后 显示 注册 成 功 ,并 返回 首页 index. php > 
?> 





通过 以 上 几 个 步骤 的 程序 编写 才能 完成 一 个 会 员 注 册 的 功能 ， 一 般 的 会 员 注册 都 是 这 样 
的 一 个 逻辑 实现 过 程 。 


EUER 找 回 密码 功能 


会 员 在 使 用 过 程 中 忘记 密码 也 是 经 常 遇 到 的 事情 ， 在 实例 中 单 击 “ 找 回 密码 ”文字 链 
接 ， 将 打开 相应 的 窗口 实现 找 回 密码 的 功能 ， 具 体 的 实现 步骤 如 下 。 

1) 在 制作 的 left_menu. php 页 面 中 加 入 JavaScript 的 验证 代码 ， 实 现 的 功能 是 单 击 “ 找 
回 密 码 ” 链 接 时 ， 打 开 openfindpwd. php 页 面 进 行 验证 ， 代 码 如 下 : 





< script language = " javascript" > 

function openfindpwd( ) | 
windows. open( " openfindpwd. php" ," newframe" ," left = 200, top = 200, width = 200, height = 100, 
menubar = no, toolbar = no location = no, scrollbars = no , location = no" ) ; 


| 
«/script > 
2) 使 用 Dreamweaver 设计 出 找 回 密码 的 页 面 如 图 9-30 所 示 ， 只 需要 一 个 简单 的 对 话 窗 
口 ， 输 入 昵称 并 进行 判断 即 可 。 











Ee C:\xampp\htdocs\shop\openfindpwd.php c mp 
BS font. css Y 




















Kd 9-30 找 回 密 码 的 页 面 
3) 在 输入 需要 找 回 密码 的 昵称 之 后 ， 单 击 “ 确 定 ”按钮 需要 进行 表单 验证 ， 判 断 是 否 


为 空 ， 如 果 不 为 空 则 指向 findpwd. php 页 面 显示 “密码 提示 ”， 输 入 提示 的 答案 ， 如 图 9-31 
所 示 。 








< script language = " javascript" > 
function chkinput( form) 
| 
if( form. nc. value =="" ) 
| 
alert(" 请 输入 您 的 昵称 1" ); 
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form. nc. select( ) ; 


return( false) ; 


| 


return( true ) ; 


| 








</script 
TË c\xampp\htdocs\shop\findpwd.php -0x 
font. css conn. php Y 





jsp i 




















密码 提示 页 面 


图 9-31 


4) 输入 “提示 答案 ”之 后 ， 再 单 击 “确定 ” 按 钮 ， 也 要 进行 表单 验证 ， 并 转向 最 终 显 


示 密 码 的 页 面 showpwd. php ， 验 证 的 代码 如 下 : 


< script language = " javascript" > 
function chkinput( form) 
| 
if( form. da. value =="") 
| 
alertt 请 输入 密码 提示 管 案 !' ); 
form. da. select( ) ; 


return( false) ; 


return( true ) ; 


| 


</script > 
< form name =" form2" method = " post" action = " showpwd. php" onSubmit = 


(this) " > 
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"return chkinput 


5) showpwd. php 的 页 面 比较 简单 ， 只 需要 查询 数据 库 ， 把 符合 条 件 的 数据 显示 出 来 ， 





即 把 昵称 和 密码 显示 在 页 面 上 即 可 ， 如 图 9-32 所 示 。 


TÈ cxampp\htdocs\shop\showpwd.php a 
ETAS font. css conn. php 





























最 终 的 显示 密码 页 面 


图 9-32 
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DES 新 闻 公告 系统 


网 站 的 “新 闻 公 告 ”在 首页 及 各 个 页 面 显示 标题 ， 当 单 击 相 应 的 标题 时 ， 打 开 详 细 的 
显示 内 容 页 面 gonggao. php。 与 网 站 的 新 闻 信息 相关 的 页 面 ， 一 共有 2 个 ，gonggao. php 用 于 
显示 具体 的 信息 内 容 ， 另 一 个 是 用 于 单 击 首页 的 “更 多 > > ”文字 链接 时 ， 打 开 所 有 的 信 
息 标 题 页 面 的 gonggaolist php。 

















ro 信息 标题 列表 


所 有 的 信息 标题 页 面 gonggaolist. php 制作 的 效果 如 图 9-33 所 示 。 








d CAxampphtdocsyshopygonggaolist.php = x 
LISSP top.php left_menu.php bottom. php Y 


PHP 电 子 商务 网 站 





页 | 最 新 上 架 | 推荐 产品 | 热门 产品 | 产品 分 类 | 用 户 中 心 | 订单 查询 | 购物 车 


Bu 

















gy: Wd ug. 
DE» y 








m E 


D E EH 753 x 346v 




















图 9-33 ”所 有 信息 标题 页 面 效 果 
该 页 面 的 编写 程序 部 分 如 下 所 示 : 


< ?php 


$sql =mysql_query( " select count( * ) as total from th_gonggao" ,$conn); 
$info = mysql. fetch, array ($sql) ; 
$total = $info| total ] ; 
if($total 2-0) 
| 
echo " 本 站 暂 无 公告 1" ; 
1// 调 用 tb_gonggao 数据 ,如 果 没 有 则 显示 “本 站 暂 无 公告 !” 
else 
| 


7» 





«table width = "530" border = "0" align =" center" cellpadding = "0" cellspacing = "0" > 









e o o 
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«tr bgcolor = " #EEEEEE" > 
< td width ="296" height ="20" > <div align =" center" > 公告 主题 </div> </td> 
< td width ="136" > < div align = " center" > 发 布 时 间 </div> </td > 
<td width ="68" > <div align ="center" > 查看 内 容 </div> </td > 
</tr> 
< ?php 
$pagesize =20; 
if ($total <=$pagesize ) | 
$pagecount =1; 
| 
if( ($total%$pagesize) 1-0) | 
$pagecount = intval($total/$pagesize) + 1; 


| else | 


$pagecount = $total/$ pagesize ; 


| 
if( ($. GET[ page ] )=="" ) | 
$page =1; 


| else | 


$page = intval($_GET[ page] ) ; 


$sqll = mysql_query ( " select * from tb_gonggao order by time desc limit ". ($ 
page — 1) *$pagesize. " ,$pagesize " ,$conn) ; 
while($infol = mysql. fetch. array ($sqll ) ) 
| 
?> 
<tr> 
<td height ="20" > «div align ="left" > — < ?php echoS$infol[ title |;? > «/div» </td > 
<td height = "20" > < div align ="center" > < ?php echo$infol[time];?» </div> </td > 
< td height = "20" > < div align = " center" > <a href = " gonggao. php?id =< ?php echo$ 
infol[id];? >" > 查看 </a> </div> </td> 
</tr> 
< ?php 


?> 
«ir» 
< td height = "20" colspan 2 "3" > &nbsp; 
< div align = " right" > 本 站 共有 公告 &nbsp; 
< ?php 











CHE 








echo $total; 
7» 
&nbsp; 条 &nbsp; 每 页 显示 &nbsp; < ?php echo $ pagesize;? > &nbsp; 条 &nbsp; 第 &nbsp; < ?php 
echo$page;? > &nbsp; 页 / 共 &nbsp; <?php echo$pagecount; ? > &nbsp; 页 
< ?php C» 





if($page >=2) 
| 
?> 
<a href = " gonggaolist. php?page =1" title =" HW" > «font face ="webdings" > 9 «/font» 
</a> «a href = " gonggaolist. php?id =< ?php echo$id;? > &amp; page =< ?php echo$page - 1;? >" 
title = " Bij— Ji" > <font face = " webdings" > 7 </font> </a> 
< ?php 
| 
if($pagecount <=4) | 
for($i 21;$i «-$pagecount;$i ++ ) | 
7» 
<a href = " gonggaolist. php?page =< ?php echo$i;? >" > <?php echo$i;? > </a> 
< ?php 
| 
| else| 
for($i=1;$i<=4;$i++ )| 
?> 
<a href = " gonggaolist. php?page =< ?php echo$i;? >" > <?php echo$i;? > </a> 
<?php }? > 
<a href = " gonggaolist. php? page =< ?php echo $page — 1;? >" title =" 后 一 页 " > < font 
face =" webdings" > 8 </font> </a> <a href = " gonggaolist. php?id =< ?php echo $id;? > &amp; 
page =< ?php echo$pagecount;? >" title = "ÆW" > « font face = "webdings" > : </font> </a> 
<?php }? > 
«/div > </td> 
</tr> 
</table > 
< ?php 


| 


?> </td> 
</tr> 
</table > 


该 页 面 的 技术 难点 在 于 新 闻 标题 的 分 页 显示 功能 ， 在 显示 的 标题 太 多 时 ， 一般 都 要 使 用 
上 述 的 分 页 显示 功能 ， 实 现 按 页 显示 记录 。 


95.2 显 示 详 细 内 容 


具体 信息 量 显示 页 面 ， 通 常 包括 显示 所 要 显示 信息 的 标题 、 时 间 以 及 出 处 ,制作 的 具体 























效果 如 图 9-34 所 示 。 


该 
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EB cxampp\htdocs\shop\gonggao.php -Dnx 
(USB top.php left menu php  function.php bottom. php TY 
Henne 


i Bi 页 | 最 新 上 架 | 推荐 产品 | 热门 产品 | 产品 分 类 | 用 户 中 心 | JASA 购物 车 
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9-34 ”详细 新 闻 页 面 





页 面 的 编写 程序 部 分 如 下 所 示 : 


«table width = "530" border ="0" align = "center" cellpadding = "0" cellspacing ="1" > 
< ?php 
$id =$_GET[ id]; 
$sql = mysql. query ( " select * from tb_gonggao where id = ". $id. " " ,$conn) ; 
$info = mysql. fetch array ($sql) ; 
include( " function. php" ) ; 

7» 
<tr> 
<td width = "24" height = "25" bgcolor = " #FFFFFF" > «div align = "center" > </div > </td > 
<td width = "315" bgcolor = "#FFFFFF" > « div align =" center" > 公告 主题 : < ?php echo unhtml($ 

info[ title] ) ;? > </div > </td > 

<td width 2 "66" bgcolor = "#FFFFFF" > « div align =" center" > 发 布 时 间 : </div > </td > 
<td width = "120" bgcolor = "#FFFFFF" > < div align = "left" > < ?php echo $info[ time] ;? > </div > 
</td> 
</tr> 
<tr> 
<td height = "125" bgcolor = " £FFFFFF" > < div align =" center" > </div > </td > 
<td height = "125" colspan 2 "3" bgcolor = "#FFFFFF" > « div align =" left" > <?php echo unhtml 
(Sinfo[ content] ) ;? > </div > </td > 

</tr> 


</table > 


通过 上 述 两 个 页 面 的 设计 ， 新 闻 公 告 系统 的 前 台 部 分 即 开发 完成 。 
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DE 产品 的 订购 功能 


购物 车 系统 主要 由 网 上 产品 订购 与 后 台 结 算 这 两 个 功能 组 成 ， 实 例 中 与 购物 车 相关 
的 产品 显示 的 页 面 就 包括 一 个 “购买 ”的 功能 按钮 。 其 中 主要 包括 index php、 用 于 显 
示 产 品 详细 信息 的 页 面 lookinfo. php, “最 新 上 架 ” 频 道 页 面 shownewpr. php，“ 推 荐 产 
品 ” 频 道 页 面 showtuijian. php, “热门 产品 ”频道 页 面 showhot. php,“ 产 品 分 类 ”频道 
页 面 showfenlei. php 、 产 品 搜索 结果 页 面 serchorder. php。 下 面 分 别 介 绍 除 首 页 以 外 的 页 
面 实现 的 功能 。 





e 

















USO 产品 介绍 页 面 











产品 介绍 页 面 lookinfo. php 是 用 来 显示 商品 细节 的 页 面 。 细 节 页 面 要 能 显示 商品 所 有 的 
详细 信息 ， 包 括 商 品 价格 、 商 品 产地 、 商 品 单位 及 商品 图 片 等 ， 同 时 要 显示 是 否 还 有 剩余 产 
品 以 及 放 入 购物 车 等 功能 ， 实 例 还 加 入 了 “商品 评价 ”。 

1) 由 所 需要 建立 的 功能 出 发 ， 可 以 建立 如 图 9-35 所 示 的 动态 页 面 。 在 页 面 中 ，PHP 
代码 图 标 代表 加 入 动态 命令 实现 该 功能 。 


[7^ CNxampphtdocsyshopVookinfo.php -0x 
edu» top.php  conn.php left menu. php bottom. php m 
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K9-35 产品 介绍 动态 页 面 
2) 该 模块 的 程序 分 析 如 下 ， 其 中 对 购物 车 的 订购 代码 进行 了 加 粗 说 明 ; 


< ?php 


$sql = mysql_query("select * from tb_shangpin where id 2 ". $ GET[ id]. "" ,$conn) ; 
$info = mysql. fetch, object($sql) ; 
7» 









QL*Dreamweaver 动态 网 站 开发 从 入 门 到 精通 





<tr> 


M" 


<td width 2 " 89" height =" 80" rowspan 2 "4" align =" center" valign =" middle" bgcolor = 


"SEFFFFF" > < div align = " center" > 


< ?php 
if( $info -» tupian dh ) | 
echo" 暂 无 图 片 " ; 
| 
else 
| 
?7> 


<a href =" < ?php echo$info —» tupian;? >" target ="_blank" > «img src =" <?php echo$info -> 
tupian;? >" alt "E XA". width ="80" height ="80" border = "0" > </a> 
< ?php 

| 

7» 
</div> </td> 
<td width = "92" height = "20" align = "left" bgcolor = " #FFFFFF" > < div align = " center" > 商品 名 
称 : «/div» </td> 
<td width = "134" bgcolor = " #FFFFFF" > < div align = " left" > &nbsp; <?php echo $ info - > 
mingcheng;? > </div > </td> 
<td width = "100" bgcolor = " #FFFFFF" > < div align = " center" > 人 市 时 间 : < /div > </td > 
<td width = "129" bgcolor 2 " #FFFFFF" > < div align =" left" > &nbsp; « ?php echo $info -> ad- 


dtime;? > «/div > </td> 


</tr> 

<tr> 

<td height 2 "20" align =" left" bgcolor = " &FFFFFF" > < div align = " center" > 会 员 价 : </div > 
</td> 


<td width = "134" bgcolor = " #FFFFFF" > < div align = " left" > &nbsp; <?php echo $ info - > 
huiyuanjia;? > «/div > </td > 

<td width = "100" bgcolor = "£FFFFFF" > « div align 2 " center" > 市 场 价 . </div> </td> 

<td width = "129" bgcolor ="#FFFFFF" > < div align =" left" > &nbsp; <?php echo$info -> shich- 
angjia;? > </div> «/id > 

</tr> 

<tr> 

<td height = "20" align = "left" bgcolor 2 " #FFFFFF" > « div align = " center" > 等 级 : </div > </td > 
<td width = "134" bgcolor = " #FFFFFF" > < div align = " left" > &nbsp; <?php echo $ info - > 
dengji;? > «/div > </td > 

<td width = "100" bgcolor = " #FFFFFF" > < div align = " center" > 品牌 : </div > </td > 

<td width = "129" bgcolor = " #FFFFFF" > < div align = " left" > &nbsp; <?php echo $info -> pin- 
pai;? > </div > </td > 

</tr> 


<tr> 
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<td height 2 "20" align = "left" bgcolor 2 " SFFFFFF" > « div align = "center" > 型 号 : «/div > </td> 
<td width = "134" bgcolor = " £FFFFFF" > < div align =" left" > &nbsp; <?php echo $info — > xing- 
hao;? > </div > </td> 

<td width = "100" bgcolor = "#FFFFFF" > « div align =" center" > 数量 : </div > </td > > 
<td width = "129" bgcolor 2 " #FFFFFF" > < div align =" left" > &nbsp; <?php echo $info - > shu- 
liang;? > </div > «/td > 








</tr> 

«tir» 

<td width = "89" height = "69" bgcolor = " #FFFFFF" > < div align = " center" > 商品 简介 : </div > 
</td> 

<td height = "69" colspan = "4" bgcolor = "#FFFFFF" valign = " top" > < div align = "left" > < br > 
&nbsp; &nbsp; &nbsp; &nbsp; < ?php echo$info —» jianjie; ? > </div > </td > 

</tr> 

</table > «/td > 

</tr> 

</table > 

<table width = "530" height 2 "20" border 2 "0" align =" center" cellpadding = "0" cellspacing = "0" > 
<tr> 

<td> «div align = "right" > <a href = " addgouwuche. php?id =< ?php echo $info -> id;? >" > 放 入 
购物 车 </a> &nbsp; &nbsp; </div > </td >// 单 击 “ 放 入 购物 车 ”传递 产品 的 Id 号 并 到 addgou- 
wuche. php 去 结算 

</tr> 








</table > 
< ?php 
if($_SESSION[ username] !- "" ) 
| 
?> 
<form name = "forml" method = "post" action =" savepj. php?id =< ?php echo $info -> id;? >" on- 
Submit = " return chkinput( this)" > 
«table width = "530" border 2 "0" align = "center" cellpadding = "0" cellspacing = "0" > 
«tr» 
<td height = "25" bgcolor = " #EEEEEE" > < div align 2 " center" style =" color; &FFFFFF" > 
< div align = " left" > &nbsp;&nbsp; < span style = " color; 8000000" > 发 表 评 论 </span > </div > 
«/div > </td> 
«/tr» 
«tr» 
< td height = "150" bgcolor = " 4999999" > < table width = " 530" border 2 "O" align =" center" 
cellpadding = "0" cellspacing 2 "1" > 
< script language = " javascript" > 


function chkinput( form) 


if( form. title. value == "" ) 


| 
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alert(" 请 输入 评论 主题 !" ) ; 
form. title. select( ) ; 
return( false) ; 
| 
if( form. content. value =="") 
| 
alert(" 请 输入 评论 内 容 1" ) ; 
form. content. select( ) ; 
return( false) ; 


| 


return( true ) ; 


«/script > 

«tr» 
«td width = "80" height = "25" bgcolor = " #FFFFFF" > < div align = " center" > 评论 主题 : «/div > 
</td> 


<td width = "467" bgcolor = "#FFFFFF" > « div align =" left" > 
«input type = "text" name =" title" size 2 "30" class = "inputcss" style = " background - color ; #e8f4ff " 
onMouseOver = " this. style. backgroundColor = sffffff " onMouseOut = " this. style. backgroundColor = 
' Re8fAfT " > 
</div> </td> 
</tr> 
<tr> 
<td height 2 "125" bgcolor = "#FFFFFF" > « div align =" center" > 评论 内 容 : </div > </td> 
<td height = "125" bgcolor = "#FFFFFF" > < div align = " left" > 
< textarea name = " content" cols = "70" rows ="10" class =" inputcss" style = " background — color :#e8f4ff " 
onMouseOver = " this. style. backgroundColor = sffffff " onMouseOut = " this. style. backgroundColor = 
' #e8f4ff " > </textarea > 
</div> </td> 
</tr> 
</table > «/td > 
</tr> 
« /table > 
< table width = "530" height = "25" border = "0" align =" center" cellpadding = "0" cellspacing = 
"0" > 
«tir» 
<td> <div align = " center" > 
< input name = " submit2" type = " submit" class = " buttoncss" value =" 发表 '" > 
&nbsp; &nbsp;&nbsp; <a href = " showpl. php?id =< ?php echo$, GET[ id] ;? >" > 查看 该 商品 评论 
</a> </div> </td> 
</tr> 
« /table > 


«/form » 








CHE 





< ?php 





3) 在 上 面 的 代码 中 ， 产 品 的 展示 只 是 数据 的 查询 及 显示 的 功能 ， 核 心 在 于 “发 表 评 
论 ”。 在 单 击 “ 发 表 ” 按 钮 时 是 传递 到 savepj. php 页 面 保存 评价 的 ， 甚 页面 的 代码 如 下 : 





< ?php 

include( " conn/conn. php" ) ; 

$title -$. POST[ title] ; 

$content 2 $. POST[ content ] ; 

$spid 2$. GET[ id]; 

$time = date(" Y -m - j") ; 

session, start( ) ; 

$sql = mysql. query(" select * from tb. user where name + ". $ SESSION[ username ]. " " ,$conn) ; 
$info = mysql. fetch array ($sql) ; 

$userid =$infol id ] ; 

mysql. query ( " insert into tb. pingjia ( userid ,spid , title, content, time) values ( $userid ', $spid ', $title , 


' $content ', $timé ) " ,$conn) ; 
echo " < script > alertt 评论 发 表 成 功 ! ) ; history. back( ) ; «/script > " ; 


7» 


SET 最 新 上 架 频 道 








单 击 导航 条 中 的 “最 新 上 架 ” 链 接 到 页 面 shownewpr. php， 该 页 面 主 要 是 显示 数据 库 中 
最 新 上 架 的 商品 。 
1) 首先 ， 完 成 静态 页 面 的 设计 ， 该 页 面 完 成 后 的 效果 如 图 9-36 所 示 。 











$ Cxampp\htdocs\shop\shownewpr.php = 0x 
UE top.php left menu php bottom. php - 


v 
is PHP 电 子 商务 网 站 页 | 最 新 上 架 | 推荐 产品 | 热门 产品 | 产品 分 类 | 用 户 中 心 | 订单 查 鹿 | 购物 车 
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图 9-36 最 新 上 架 的 静态 页 面 效果 
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2) 代码 主要 核心 部 分 如 下 所 示 : 


«table width = "550" height = "70" border ="0" align =" center" cellpadding = "0" cellspacing = "0" > 
< ?php 
$sql = mysql. query ("select * from tb. shangpin order by addtime desc limit 0,4" , $conn) ; 
// 从 产品 表 中 调 出 最 新 加 入 的 4 条 产品 信息 
$info = mysql. fetch array ($sql) ; 
if( $info == false) | 
echo " 本 站 暂 无 最 新 产品 1" s 
| 
else f 
do! 
?> 
<tr> 
<td width = "89" rowspan = "6" > « div align = " center" > 
< ?php 
if($info[ tupian] 22 "" ) | 
echo" 暂 无 图 片 1"; 
| 
else | 
?> 
<a href = " lookinfo. php?id =< ?php echo $info[ id] ;? >" > «img border = "0" src =" <?php echo $ 
info[ tupian] ;? >" width 2 "80" height = "80" > </a> 
< ?php 
| 
7» 
</div> </td> 
<td width = "93" height 2 "20" > « div align 2" center" style =" color; #000000" > 商品 名 称 : </div > 
</td> 
<td colspan 2 "5" > <div align = "left" > <a href = " lookinfo. php?id =< ?php echo $info[ id];? >" > 
< ?php echo $info[ mingcheng] ;? > </a > </div > </td> 
</tr> 
<tr> 
<td width = "93" height = "20" > < div align =" center" style =" color; #000000" > 商品 品牌 : </div > 
</td> 
<td width ="101" height = "20" > <div align =" left" > < ?php echo $info[ pinpai ] ;? > </div > </td > 
<td width = "62" > «div align 2 " center" style = "color; #000000" > 商品 型 号 . </div> </td> 
<td colspan ="3" > <div align = "left" > < ?php echo $info[ xinghao] ;? > </div > </td > 


</tr> 

<tr> 

<td width = "93" height = "20" > < div align =" center" style =" color; #000000" > 商品 简介 : </div > 
</td> 


«td height = "20" colspan ="5" > < div align = " left" > <?php echo $info[ jianjie] ;? > </div > 
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</td> 

</tr> 

<tr> 

<td height = "20" > <div align = " center" style =" color; #000000" > 上 市 日 期 : «/div» </td> © 
<td height = "20" > «div align = "left" > < ?php echo$infol addtime ] ;? > </div > «/td > 

<td height 2 "20" > <div align 2 " center" style =" color; #000000" > PAŽE: </div> </td> 

<td width = "69" height 2 "20" > < div align = "left" > <?php echo $info[ shuliang ] ;? > «/div > 

</td> 


<td width = "63" > «div align 2 " center" style = "color; #000000" > 商品 等 级 . </div> </td> 
<td width = "73" > <div align = "left" > < ?php echo $info[ dengji] ;? > «/div» </td> 





</tr> 

<tr> 

<td height = "20" > «div align = " center" style =" color; #000000" > 商场 价 : </div > </td > 

« td height 2 "20" > «div align = "left" > « ?php echo $info[ shichangjia] ;? > 76 </div > </td > 
<td height 2 "20" > «div align = " center" style =" color; #000000" > 会 员 价 : </div> </td> 

<td height = "20" > «div align = "left" > <?php echo $info[ huiyuanjia] ;? > 76 « /div > «/td > 

<td height = "20" > «div align = " center" style =" color: 4000000" > 折扣 : «/div > «/td > 

<td height = "20" > < div align = " left" > <?php echo ( 9 ceil ( ($info[ huiyuanjia ]/$ info [ shich- 
angjia]) * 100) ). "96" ;?» </div> </td> 

</tr> 

«tir» 

<td height = "20" colspan 2 "6" width 2 "461" > < div align =" center" > &nbsp; &nbsp; &nbsp; 
&nbsp; <a href = " addgouwuche. php?id =< ?php echo $info[ id];? >" > «img src =" images/bl. gif" 
width 2 "50" height 2"15" border = "O" style=" cursor: hand" > </a> «/div > </td> 

</tr> 

«tir» 

<td height = "10" colspan 2 "7" background = " images/linel. gif" > «/td > 

</tr> 

< ?php 

| while($info = mysql. fetch. array ($sql) ) ; 

| 

7» 


« /table » 


9% 推荐 产品 频道 


单 击 导 航 条 中 的 “推荐 产品 ”链接 到 页 面 showtuijian. php， 该 页 面 主 要 是 显示 数据 库 中 
推荐 的 商品 。 

1) 首先 ， 完 成 静态 页 面 的 设计 ， 该 页 面 完 成 后 的 效果 如 图 9-37 所 示 。 

2) 推荐 产品 的 功能 和 最 新 上 架 频 道 功能 基本 上 一 样 ， 不 同 的 地 方 在 于 推荐 时 从 数据 库 
查询 的 代码 不 一 样 ， 主 要 核心 的 不 同 部 分 如 下 所 示 : 
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动 C:\xampp\htdocs\shop\showtuijian.php 





ETAS top.php left_menu.php bottom. php 


产品 分 类 | 用 户 中 心 | 订单 查询 | 购物 车 


Ww v3 m. m 





SA 
































« ?php 
$sql = mysql. query ( " select count( * ) as total from tb. shangpin where tuijian 2 1 " , $conn) 
// K. tb. shangpin 数据 表 中 查询 出 tuijian 2 1 的 商品 
$info = mysql. fetch array ($sql) ; 
$total = $info| total ] ; 
if($total 2-0) 
| 
echo " 本 站 和 暂 无 推荐 产品 1" ; 
| 


else 


| 


7» 


SUL 热 门 产品 频道 





单 击 导航 条 中 的 “热门 产品 ”链接 到 页 面 showhot. php， 该 页 面 主 要 是 显示 数据 库 中 热 
门 的 商品 。 
1) 首先 ， 完 成 静态 页 面 的 设计 ， 该 页 面 完成 后 的 效果 如 图 9-38 所 示 。 
2) 热门 产品 的 功能 主要 核心 不 同 部 分 如 下 所 示 : 
< ?php 
$sql = mysql query(" select * from tb. shangpin order by cishu desc limit 0,10" ,$conn) ; 
// M. tb. shangpin 数据 表 中 查询 出 10 条 的 热门 产品 
$info = mysql. fetch. array ($sql) ; 
if( $info == false) 
| 
echo " 本 站 和 暂 无 热门 产品 1" s 
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do 
函 CAxampp\htdocs\shop\showhot.php -Dx 
top.php left menu.php bottom. php 












































图 9-38 热门 产品 的 静态 页 面 效 果 


NEM 产品 分 类 频道 


单 击 导航 条 中 的 “热门 产品 ”链接 到 页 面 showfenlei. php， 该 页 面 按 商 品 的 分 类 显示 不 


同 的 商品 。 


1) 首先 ， 完 成 静态 页 面 的 设计 ， 该 页 面 完成 后 的 效果 如 图 9-39 所 示 。 
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PHP 电 子 商 务 网 站 


e 我 的 购物 车 
BA: 游客 ， 欢 迎 您 ! 
请 先 登 录 ， 后 购物 
您 的 购物 车 为 空 


Y 


用 户 : | 
密码 :[ 
全 证 : |[ 779 


[€ X] 注册 找 回 密码 








e AA 7 E] http//127.0.0.1/shop/showfenlei.php 
电子 商务 网 站 x 


首 页 | 最 新 上 架 | 推荐 产品 


商品 名 称 : 


商品 品牌: 


| 热门 产品 | 产品 分 类 | 用 户 中 心 | 订单 查询 | 购物 车 


产品 分 类 : MARR 办 公 耗 村 办 公设 备 办 公用 纸 办 公文 县 
ZR» da 


商品 型 号 : adti an001 
Ei ru CEA] 
2011-6-1 剩余 数量 : 10 

会 员 价 : 1000 元 


deo? 

Adtian 商品 型 号 : adtian002 
爱 德 天 的 第 二 款 办 公 卓 

2011-6-1 剩余 数量 : 10 

1600 元 会 员 价 : 1200 元 





Qro 


















































PHP 网 上 购物 系统 前 台 
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2) 分 类 的 功能 主要 核心 不 同 部 分 如 下 所 示 : 


< ?php 
if($ GET[ id] 22"") 
| 
$sql =mysql_query( " select * from tb, type order by id desc limit 0,1" ,$conn) ; 
// MJ. ib. type 数据 表 中 查询 出 所 有 的 商品 分 类 
$info = mysql. fetch array ($sql) ; 
$id =$infof id]; 


else 


$id 2$ GET[id]; 
| 
$sqll = mysql_query(" select ** from tb. type where id =". $id. "" ,$conn) ; 
$infol = mysql. fetch. array ($sqll) ; 


$sql = mysql. query ( " select count( * ) as total from tb. shangpin where typeid = ". $id. " order by 
addtime desc " ,$conn) ; 
$info = mysql. fetch array ($sql) ; 
$total = $info| total ] ; 
if($total 220) 
| 
echo " < div align + centet > 本 站 暂 无 该 类 产品 ! </div>"; 


9.6.6 产品 搜索 结果 


一 般 的 大 型 网 站 都 没有 搜索 功能 ， 在 首页 中 要 设置 商品 搜索 功能 。 输 入 搜索 的 商品 名 
称 ， 单 击 搜索 按钮 后 ， 要 打开 的 页 面 就 是 这 个 商品 搜索 结果 页 面 serchorder. php. 

1) 由 上 面 的 功能 分 析出 发 ， 设 计 好 的 商品 搜索 结果 页 面 如 图 9-40 所 示 。 

2) 相关 的 程序 代码 分 析 如 下 : 


< ?php 

$jdez 2$. POST[ jdez ] ; 
$name - $. POST| name] ; 
$mh =$_POST[ mh]; 
$dx 2$ POST[ dx] ; 
if($dx 22 "1")| 

$dx=" >"; 











B Cxampp\htdocs\shop\serchorder.php 
ZB conn php top.php left menu.php bottom. php 





H t 
Ed 
J> |4] x 





























B E EH 7% x 377v 








图 9-40 ”产品 搜索 结果 页 面 


| 


elseif($dx ==" -1")| 
$dx="<"; 
| 

else| 
$dx =" ="; 


| 
$jg = intval($_POST[ jg] ) ; 
$lb 2$ POST[Ib] ; 
if($jdez12 " ")| 
$sql = mysql query("select * from tb, shangpin where mingcheng liké 96". $name. "% order by ad- 
dtime desc" , $conn) ;// 按 分 类 名 称 查 询 tb. shangpin 数据 表 
| 
else 
| 
if($mh =="1" )| 
$sql = mysql_query( " select * from tb, shangpin where huiyuanjia $dx". $jg. " and typeid = ". $1b." 
and mingcheng like 96". $name. " 95 " ,$conn) ; 
1// 按 会 员 价 查询 由 _shangpin 数据 表 
else| 
$sql = mysql query (" select * from tb, shangpin where huiyuanjia $dx". $jg. " and typeid = ". $1b. " 


and mingcheng = ". $name. " " ,$conn) ; 


| 
| 
$info = mysql_fetch_array($sql ) ; 
if( $info ==false) | 
echo " < script language + javascript > alert( 本 站 暂 无 类 似 产品 ! ) ; history. go( -1); </script>"; 
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else | 
7» 
«table width = " 530" border 2 "O0" align = " center" cellpadding = "O" cellspacing =" 1" bgcolor = 
"4CCCCCC" > 
<tr bgcolor = " £FOFOF0" > 
«td width = "92" height 2 "25" > < div align = " center" style = " color; #990000" > 4 ff «/div > 
</td> 
<td width = "83" > « div align = " center" style = " color; #990000" > mhf </div > </td> 
<td width = "62" > <div align = " center" style = " color; #990000" > 市 场 价 </div> </td > 
<td width = "62" > <div align = " center" style = " color; #990000" > 会 员 价 «/div» </td > 
<td width = " 161" > « div align =" center" style = " color; #990000" > 上 市 时 间 </div > «/td > 
<td width = "48" > < div align =" center" style 2 " color; #FFFFFF" > < span class =" stylel" > 
</span > «/div > </td> 
<td width = "42" > « div align = " center" style = " color; #990000" > 操作 «/div» </td> 
</tr> 
< ?php 
do| 
7» 
«tr bgcolor = "&FFFFFF" > 
<td height 2 "25" > «div align = " center" > < ?php echo$info[ mingcheng] ;? > «/div > </td > 
<td height 2 "25" > «div align = " center" > < ?php echo$info[ pinpai];? > «/div > </td> 
<td height = "25" > «div align = " center" > < ?php echo $info[ shichangjia] ;? > </div > </td > 
<td height = "25" > «div align = "center" > < ?php echo $info[ huiyuanjia] ;? > «/div > </td > 
<td height = "25" > «div align = " center" > < ?php echo$info[ addtime] ;? > «/div» </td > 
<td height 2 "25" > «div align =" center" > «a href = " lookinfo. php?id =< ?php echoS$info[ id];? >" > 
EF </a> </div> </td> 
<td height 2 "25" > < div align =" center" > < a href = " addgouwuche. php?id =< ? php echo $ info 
[id];? >" > 购物 </a> </div> </td> 
</tr> 
< ?php 
| while ($info = mysql. fetch, array ($sql) ) ; 
| 








?> 
</table > </td > 
</tr> 
</table > 
到 这 里 ， 就 完成 了 与 商品 相关 动态 页 面 的 设计 ， 可 以 实现 网 站 产品 的 前 台 展 示 和 订购 的 


功能 。 


网 站 的 结算 功能 


网 站 的 核心 技术 ， 就 在 于 产品 的 展示 与 网 上 订购 、 结 算 功 能 ， 在 网 站 建设 中 这 部 分 知识 














统称 为 “购物 车 系统 ”。 购 物 车 最 实用 的 功能 就 是 可 进行 产品 结算 ， 通 过 这 个 功能 ， 用 户 在 
选择 了 自己 喜欢 的 产品 后 ， 可 以 通过 网 站 确认 所 需要 的 产品 ， 输 入 联系 方式 ， 提 交 后 写 人 数 
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据 库 ， 方 便 网 站 管理 员 进 行 售后 服务 ， 这 也 就 是 购物 车 的 主要 功能 。 








所 示 。 


订单 的 统计 


addgouwuche. php 页 面 在 前 面 的 代码 中 经 常用 到 ， 就 是 单 击 “ 购 买 ”图 标 按钮 后 ， 需 要 
调用 的 页 面 ， 主 要 是 实现 统计 订单 数量 的 功能 页 面 。 该 页 面 完 全 是 PHP 代码 ， 如 图 90-41 





È CAxampp\htdocs\shop\addgouwuche.php 
conn. php 

K?php 

session_start () ; 

include ("conn/ conn. php") ; 
if($ SESSION[username]--"") 


{ 
echo “<script>alert( 请 先 登录 后 购物 !*) :history. back(); /script?"; 
exit; 


} 
$id=strval ($_GET [id]) ; 
$sql-mysql query("select * from tb shangpin where id-'".$id."'",$conn); 
$info-mysql fetch array($s31); 
if ($info[shuliang]4-0) { 
echo “<script>alert ( RAMEE! ) ;history. back () : </script>" ; 


(o 0 -10 c1 co ni 


exit; 
H 
$arraycexplode("&",$ SESSION[producelist]): 
for ($i=0;$i<count ($array)-1;$i+){ 
if ($array[$i]==$id) { 
echo “<script>alert( 该 商品 已 经 在 您 的 购物 车 中 !") history. back </script>" ; 
exit; 


} 


$ SESSION[producelist]-$ SESSION[producelist]. $id. "à"; 
$ SESSION[quatity]-$ SESSION[quatity]."1&": 
header (" location: gouwuche. php") ; 

?> 





a 
E 
H3 
E 
z 
«| 
{i} 
图 
公 
Q 
tà 
gy 
ll 
h, 
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图 9-41  addgouwuche. php 页 面 的 设计 


代码 分 析 如 下 : 


< ?php 
session, start( ) ; 
include( " conn/conn. php" ) ; 
if($ SESSION[ usemame] == "")| 
echo " < script > alert( WER KJA AI! ) ; history. back( ) ; </script>" ; 
exit ; 
1 判断 是 否 已 经 登录 
$id = strval($_GET[ id] ) ; 
$sql = mysql query("select * from tb shangpin where id = ". $id. " " ,$conn) ; 
$info = mysql. fetch array ($sql) ; 
if( $info[ shuliang] <=0) | 
echo " < script > alert( 该 商品 已 经 售 完 !' ) ; history. back( ) ; </script>" ; 
exit ; 


1 判断 是 否 还 有 产品 


CHE 





e 
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$array = explode("@" ,$ SESSION[ producelist] ) ; 
for($i 20;$i < count($array) —1;$i ++ ) | 
if($array[$1] ==$id) | 
echo " < script > alert( 该 商品 已 经 在 您 的 购物 车 中 ! ) s history. back ( ) ; « script >" ;// 判 


exit; 


| 
$. SESSION[ producelist] 2$. SESSION[ producelist]. $id. "  " ; 
$. SESSION[ quatity] 2$. SESSION[ quatity ]. "19" ; 
header( " location ; gouwuche. php" ) ;实现 统计 累加 的 功能 并 进行 转向 
7» 
说 明 : 
session 是 在 PHP 编程 技术 中 ， 占 有 非常 重 edid 为数 。 由 于 网 页 是 一 种 无 状态 的 链 
接 程序 ， 因 此 无 法 得 知 用 户 的 浏览 状态 。 必 过 session 变量 记录 用 户 的 有 关 人 信息， 供用 
户 再 次 以 此 身份 对 服务 器 提出 要 求 时 做 出 确认 。 


在 购物 车 订购 过 程 中 ， Bu md “删除 ”或 “清空 购物 车 ”文字 链接 ， 能 够 调用 re- 
movegwc. php 页 面 ， 通 过 里 面 的 命令 Sed ueque 设计 的 PHP 代码 如 图 9-42 








所 示 。 
清除 订单 的 代码 如 下 : 
< ?php 
session, start( ) ; 
$id-$ GET[id]; 
Sarraysp = explode ( " 9 " ,$ SESSION[ producelist ] ) ; 
Sarraysl = explode( " @ " ,$ SESSION[ quatity ] ) ; 
for($i 20;$i < count($arraysp) ;$i ++ ) | 
if($arraysp[$i] ==$id) | 
$arraysp[$i] =""; 
$arraysl[$i] =""; 
| 
| 
$_SESSION[ producelist] = implode( " @ " ,$arraysp ) ; 
$. SESSION[| quatity ] = implode( " @ " , $arraysl) ; 
header( " location :gouwuche. php" ) ; 
7» 
通过 上 面 的 命令 可 空 购物 车 里 的 订单 ， 并 返回 gouwuche. php 重新 进行 订购 。 
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session start(); 
$id-$ GET[id]; 
$arraysp-explode("QG",$ SESSION[producelist]); 
$arraysl-explode("QG",$ SESSION[quatity]); 
for($i=0;$i<count ($arraysp) ;$i++){ 
if(Sarraysp[$i]--$id)t 
Sarraysp[$i]-""; 
$arraysl[$i]-2""; 
} 

} 
$_SESSION[producelist]=implode("@",$arraysp); 
$_SESSION[quatity]=implode("@",$arraysl); 
header ("location: gouwuche. php") ; 

?> 


图 9-42 


removegwc. php 页 面 















"购物 车 信息 


用 户 登 录 后 选择 商品 放 入 购物 车 ， 单 击 首页 上 的 “去 收银 台 ” 文 字 链 接 ， 则 打开 订单 
用 户 信息 确认 页 面 gouwusuan. php， 在 该 页 面 中 需要 输入 收 货 人 的 详细 信息 ， 设 置 的 结果 如 


图 9-43 所 示 。 





È CAxampp\htdocs\shop\gouwusuan.php 











RD top.php left_menu.php bottom. php 


iH 页 | 最 新 上 架 | 推荐 产品 








产品 | 产品 分 类 | 用 户 中 心 | 





订单 查询 | 购物 车 




















X 





B E EH 805 x 434» 





9-43 ”订单 确认 页 面 





PAPE 生成 订单 


单 击 “提交 订单 ”按钮 后 ， 则 调用 savedd. php 页 面 。 该 页 面 的 功能 是 把 订单 写 人 数据 
库 后 返回 gouwusuan. php 页 面 ， 具 体 代 码 如 下 : 
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< ?php 

session, start( ) ; 

include( " conn/conn. php" ) ; 

$sql = mysql. query(" select * from tb. user where name + ". $ SESSION[ username]. " " ,$conn) ; 
$info = mysql. fetch array ($sql) ; 
$dingdanhao = date( " YmjHis" ). $info[ id] ; 
$spc 2 $. SESSION[ producelist ] ; 

$slc = $ SESSION[ quatity ] ; 

$shouhuoren =$_POST[ name2 | ; 

$sex 2$. POST| sex ] ; 

$dizhi 2$. POST[ dz]; 

$youbian 2$. POST[ yb]; 

$tel 2$. POST[ tel]; 

$email 2$, POST[ email ] ; 

$shff -$ POST[shff] ; 

$zfff - $. POST[ zfff] ; 

if(trim($. POST[1y]) 22"")| 


$leaveword = "" ; 


| 


else | 
$leaveword 2$. POST[1y] ; 

| 

$xiadanren =$_SESSION[ username | ; 

$time = date(" Y -m -j H:i:s"); 

$z = "未 作 任何 处 理 " ; 

$total =$_SESSION[ total ] ; 
mysql. query( " insert into tb_dingdan ( dingdanhao, spc, slc , shouhuoren , sex, dizhi , youbian , tel , email, 
shff, zfff,leaveword , time, xiadanren, zt, total) values ( $ dingdanhaó ', $ spé ', $ slé ', $ shouhuoren , 
' $sex , $dizhi ', $youbiat ; $tel ', $email ', $shff ', $zfff ', $leaveword ', $time ', $xiadanren ', $zt , 
$total )" ,$conn) ; 
header( " location: gouwusuan. php?dingdanhao = $dingdanhao" ) ; 


7» 


9.7.5 


用 户 在 购物 的 时 候 ， 还 需要 知道 自己 在 近期 一 共 购 买 了 多 少 商品 。 单 击 导航 条 上 的 
“订单 查询 ”命令 ， 打 开 查 询 输入 的 页 面 finddd. php， 在 查询 文本 域 中 输入 客户 的 订单 编号 
或 者 下 订单 人 姓名 ， 都 可 以 查 到 订单 的 处 理 情况 ， 方 便 与 网 站 管理 员 的 沟通 。 订 单 查询 功能 
和 首页 上 的 商品 搜索 功能 设计 方法 是 一 样 的 ， 需 要 在 输入 的 查询 页 面 设置 好 连接 库 的 连接 ， 
设置 查询 输入 文本 域 ， 建 立 查 询 命 令 。 具 体 的 设计 分 析 同 前 面 的 搜索 功能 模块 设计 相同 ， 完 
成 的 效果 如 图 9-44 所 示 。 
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TÈ cxampp\htdocs\shop\finddd.php -Dx 


top.php left menu php bottom. php Y 


: 12 
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图 9-44 订单 查询 页 面 效 果 


通过 本 章 的 介绍 ， 整 个 购物 系统 网 站 前 台 的 动态 功能 的 核心 部 分 都 已 经 介绍 完 ， 其 他 一 
些小 功能 页 面 这 里 就 不 做 具体 的 介绍 ， 用 户 在 使 用 时 ， 可 以 根据 自己 的 需求 对 网 站 进行 一 定 
的 完善 和 更 改 ， 达 到 自己 的 使 用 要 求 。 





^r^ 


zB PHP 网 上 购物 系统 后 全 开发 


一 个 完善 的 网 上 购物 系统 不 仅 要 提供 给 用 户 注册 、 购 物 的 功能 ， 它 还 要 提供 给 网 站 所 有 
者 一 个 功能 齐全 的 后 台 管 理 功能 ， 例 如 ， 网 站 所 有 者 登录 后 台 即 可 进行 发 布 新 公告 、 会 员 注 
册 管 理 、 回 复 留言 、 商 品 维护 ， 以 及 订单 的 管理 。 本 意 主要 介 绍 使 用 PHP 进行 网 上 购物 系 


统 后 台 开 发 的 方法 。 





s AATJE EI: 


主要 掌握 以 下 知识 点 


购物 系统 后 台 的 架构 设计 
后 台 登 录 的 商品 管理 功能 
后 台 的 用 户 管理 功能 

后 台 的 订单 管理 功能 

后 台 的 信息 管理 功能 








购物 系统 后 台 的 架构 设计 
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发 











购物 车 后 台 管理 系统 是 整个 网 站 建设 的 难点 ， 它 包括 了 几乎 所 有 的 常用 PHP 处 理 技术 ， 
实例 的 后 台 主 要 要 实现 “商品 管理 ”"”、“ 用 户 管理 ”、“ 订 单 管理 "*"、“ 信 息 管理 ”4 大 功能 模 





块 。 和 网 站 前 台 的 制作 方法 一 样 ， 在 进行 具体 的 功能 开发 之 前 ， 首 先 要 进行 一 个 后 台 的 需求 


整体 规划 。 


IUS 后 人 台 整 体 规划 


本 实例 将 所 有 制作 的 后 台 管理 页 面 放置 在 admin 文件 夹 下 ， 和 单独 设计 一 个 网 站 一 样 ， 
需要 建立 一 些 常 用 的 文件 来， 如 用 于 连接 数据 库 的 文件 夹 conn、 用 于 放置 网 页 样式 表 的 文 
件 夹 css， 放 置 图 片 的 文件 夹 images， 以 及 用 于 放置 上 传 产品 图 片 的 文件 夹 upimages。 设 计 





完成 的 整体 文件 夹 及 文件 如 图 10-1 所 示 。 








QGU- |. « xampp » htdocs » shop » admin » 





~ [5l] ££ admi p 





; 文件 (有 ”编辑 (E) SEV) 工具 (T) ”帮助 (H) 





目 changeleaveword.php 


|. deleteleaveword.php 











10-1 网 站 后 台 文 件 结构 


对 需要 设计 的 页 面 功能 分 析 如 表 10-1 所 示 。 


|. deletepingiia.php 

















组 织 Y 包含 到 库 中 v 共享 刻录 新 建文 件 夫 (88 " | m e 
yr 收藏 夫 E |; conn p css E 
|. Creative Cloud |; images |, upimages 
B 下 载 E Lj addgonggao.php L.jaddgoods.php za 
mE SE Lj addleibie.php Lj admingonggao.php 
35] 最 后 访 问 的 位 置 Lj changeadmin.php Lj changegoods.php 


L.] chkadmin.php 


ar | default.php |. deleteallip.php 
Bux Li deletedd.php |] deletefxhw.php 
加 图 片 Li deletegonggao.php |] deletelb.php 


X 10-1 购物 系统 后 台 页 面 功能 分 析 




















网 站 后 台 文 件 主要 功能 

addgonggao. php 增加 新 公告 的 页 面 
addgoods. php 增加 商品 信息 的 页 面 
addleibie. php 增加 商品 类 别 的 页 面 





admingonggao. php 














changeadmin. php 


增加 商品 公告 的 页 面 
AR 


管理 员 信息 变更 页 面 











changegoods. php 


商品 信息 变更 页 面 











网 站 后 台 文 件 


PHP+MYSQL+Dreamweaver x 








changeleaveword. php 





chkadmin. php 











conn/ conn. php 


























default. php 








后 台 登 录 后 的 首页 



































































































































































































































deleted. php I 除 订单 的 页 面 
deletefxhw. php 除 商 品 信息 页 面 
deletegonggao. php 除 公告 信息 页 面 
deletelb. php 除 商 品 大 类 页 面 
deleteleaveword. php 作用 户 留言 页 面 
deletepingjia. php 除 商 品评 论 页 面 
deleteuser. php 除 用 户 信息 页 面 
dongjieuser php 冻结 用 户 处 理 页 面 
editgonggao. php 编辑 公告 内 容 页 面 
editgoods. php 编辑 商品 信息 页 面 
editleaveword. php 编辑 用 户 留言 页 面 
editpinglun. php 编辑 用 户 评论 页 面 
edituser php 编辑 用 户 信 息 页 面 
finddd. php 订单 查询 页 面 
function. php 调用 的 常用 函数 
index. php 后 台 用 户 登 录 
left php 展开 式 树 状 导 航 条 




















lookdd. php 


























lookleaveword. php 查看 用 户 留言 页 面 
lookpinglun. php 查看 用 户 评论 页 面 
lookuserinfo. php 查看 用 户 信 息 页 面 


























orderdd. php 








saveaddleibie. php 











savechangeadmin. php 



































savechangegoods. php 





saveeditgonggao. php 


保存 经 修改 公告 内 容 



























































savenewgonggao. php 保存 新 增 公告 信息 
savenewgoods. php 保存 新 增 公告 信息 
saveorder. php 保存 执行 订单 页 面 
showdd. php 打印 订单 的 功能 页 面 
showleibie. php 商品 大 类 显示 页 面 




















top. php 








后 台 管 理 的 顶部 文件 
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PHP 网 上 购物 系统 后 台 开 发 








从 上 面 的 分 析 统 计 看 到 该 网 站 后 台 总 共 由 42 个 页 面 组 成 ， 从 开发 的 难 易 度 来 看 并 不 比 
前 台 的 开发 简单 。 


DE 登录 管理 流程 


后 台 的 功能 开发 和 网 站 的 前 台 功 能 开发 并 不 大 一 样 ， 前 台 除 了 功能 的 需求 之 外 ， 还 需要 
讲究 更 多 的 网 页 布局 即 网 站 的 美工 设计 ， 后 台 的 开发 则 主要 重视 功能 的 需求 开发 ， 而 网 页 美 
工 可 以 放 到 其 次 ， 因 为 使 用 后 台 的 就 是 网 站 所 有 者 那么 一 两 个 人 。 本 小 节 将 介绍 网 站 后 台 从 
登录 到 可 实现 的 管理 具体 有 哪些 流程 ， 以 方便 读者 更 容易 了 解 后 面 小 节 的 内 容 。 

1) 对 于 网 站 所 有 者 需要 登录 后 台 进 行 网 上 购物 系统 的 管理 ， 由 于 涉及 很 多 商业 机 密 ， 
所 以 需要 设计 登录 用 户 确认 页 面 ， 通 过 输入 唯一 的 用 户 名 和 密码 来 登录 后 台 进 行 管理 。 本 网 
上 购物 系统 为 了 方便 使 用 ， 只 需要 在 首页 用 户 系 统 中 直接 输入 “用 户 名 ” (admin) 和 “ 密 
人 码 ”(admin) ， 登 录 的 地 址 为 : http://127. 0. 0. L/shop/admin/login. php, ， 如 图 10-2 所 示 。 


























eO) 个 人 * E] htp://127.0.0.1/shop/admin/login.php $ p-Box| (xx i8 
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图 10-2 后 台 管 理 登 录 页 面 
2) 单 击 “ 登 录 ” 按 钮 即 可 以 登录 后 台 的 首页 进行 全 方位 的 管理 ， 如 图 10-3 所 示 。 
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O AMA ~ LE] http://127.0.0.1/shop/admin/default.php 


系统 












收 货 方式 
普通 平邮 未 作 任何 处 理 查看 | | 执行 
普通 平邮 未 作 任何 处 理 *é | 执行 n 
特快 专递 未 作 任何 处 理 mé Wü rr 





订单 号 IFRS 
^ meg 2011062801112144 test | 刘 小 小 2410 
9 添加 类 别 2011062801091944 test | 刘 小 小 2410 


T APEE j 2011061508081144 test FIA 100 































































C r ee 
^ cm 
^ mim 
C Weg 
^ 管理 公告 
^ 发布 公告 
> em 




















图 10-3 后 台 管理 主 界面 
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3) 单 击 左 边 树 状 管理 菜单 中 的 “商品 管理 ”， 可 以 展开 包含 “增加 商品 ”“ 修 改 商 品 ” 
“类 别管 理 ”“ 添 加 类 别 ”4 个 功能 菜单 项 ， 通 过 这 4 个 功能 ， 主 要 实现 商品 的 添加 、 修 改 
管理 。 如 图 10-4 所 示 为 增加 商品 页 面 。 
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€ || A|| A || X | [© |http://127.0.0.1/shop/admin/default.php Bex 





商品 管理 

e 。 增加 商品 
etas 商品 各 称 : | 
2 发 布 时 间 : de - i 81] B 
日 “添加 类 别 

SE BEME miaf 元 会 员 价 元 
UP ree T Minn RA v 
» 会 员 管理 商品 等 级 : Wmv 
° ZEER aaae: 站 一 
^ HERA Wee. 

六 “订单 管理 ) 是 否 推荐 : 是 ~ 
> 编辑 订单 商品 数量 : 
^ sni 商品 图 片 : IME. 
C > 信息 管理 1 
e 管理 公告 
e 发 布 公告 商品 简介 : 


^ EHE 















后 台 管 理 系统 


























图 10-4 增加 商品 页 面 


4) 如 果 想 实现 对 用 户 的 管理 ， 可 以 单 击 “ 用 户 管理 ”展开 式 菜单 ， 里 面包 括 了 “会 员 
管理 “留言 管理 ”， 以 及 “更 改 管理 员 ”3 个 菜单 项 ， 在 这 3 个 功能 中 ， 后 台 管 理 者 不 但 
可 以 实现 对 注册 会 员 的 删除 管理 ， 还 可 以 实现 相应 留言 的 删除 管理 ， 对 于 后 台 登 录 的 admin 
身份 也 可 以 进行 变更 。 如 图 10-5 所 示 为 后 台 管理 者 变更 页 面 。 
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会 员 管理 
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编辑 订单 
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管理 公告 
发 布 公告 
管理 评价 








图 10-5 后 台 管 理 者 变更 页 面 


5) 订单 管理 是 购物 系统 后 台 管 理 的 核心 部 分 ， 单 击 “ 订 单 管理 ”展开 式 菜 单项 ， 可 以 
看 到 包括 了 “编辑 订单 ”和 “查询 订单 ”两 个 功能 项 。 其 中 编辑 订单 就 是 实现 前 台 会 员 下 
订单 后 与 管理 员 进行 交互 ， 管 理 员 需 要 及 时 处 理 订单 ， 并 进行 发 货 方 要 完成 的 购物 交易 的 环 
节 。 编 辑 订单 的 页 面 如 图 10-6 所 示 。 
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销售 管理 系统 


e 增加 商品 
o 修改 商品 
^ e 
^ 添加 类 别 RTÆS: 2011062801112144 

PEEET [SS do: 





: Snes 协 ' 公 卓 -01 
^ 留言 管理 EX 
P ERREA EE 
一 [sS 20 
o 编辑 订单 ig 
em KA: 刘 小 小 
Xm 收 线 人 地 址 北京 朝 B 双 本 12 号 
> 。 信息 管理 BP 编 : 101121 Hj 话 : 13800138000 
^ 管理 公告 E-mail. desi gnem@163. com 
o Exi EE 支付 方式 : 建设 良 行 汇款 
S ERDiBNISe: 汇款 后 请 及 时 联系 我 们 
^ 管理 评价 


















































图 10-6 编辑 订单 页 面 
6) 单 击 “ 信 息 管 理 ” 展 开 式 菜单 ， 其 中 包括 了 “管理 公告 ” “发 布 公告 ”以 及 “管理 
评价 ”3 个 功能 。 通 过 这 3 个 功能 ， 能 够 实现 整个 网 站 的 即时 新 闻 发 布 、 公 告 修改 以 及 商品 
评论 的 编辑 修改 功能 ， 如 图 10-7 所 示 。 











增加 商品 
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> emm 
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P ERER 
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9 发布 公告 
^ 管理 评价 





理性 选择 原装 耗 村 或 通用 耗材 

我 国 纸 业 三 大 热点 值得 关注 

用 办 公文 具 组 装 星 战 模型 

加 强 出 口 铝 笔 检验 监管 

中 国 低 矿产 品 认 证 启动 

欧盟 纳米 村 料 法 规 的 最 新 进展 

[Zl Lr | 本 站 共有 公告 6 条 每 页 显示 20 条 









































图 10-7 管理 公告 页 面 
上 述 的 后 台 管 理 系 统 从 登录 到 各 功能 的 管理 页 面 来 看 ， 后 台 管 理 功 能 非常 流畅 ， 能 够 提 
供 非常 便利 的 网 站 管理 后 台 前 提 是 需要 网 站 设计 者 与 管理 员 沟 通 到 位 ， 问 清 需 求 后 ， 方 可 规 
划 出 实用 的 网 站 后 台 。 


IUBE 后 台 登 录 的 设计 


一 般 后 台 管理 员 在 进行 后 台 管 理 时 都 需要 先进 行 身 份 验证 。 实 例 用 于 登录 的 页 面 如 
图 10-8 所 示 ， 在 单 击 “登录 ”按钮 后 ,确认 后 人 台 登 录 管理 身份 的 动态 文件 为 chkad- 
min. php, 
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图 10-8 后 台 管 理 员 登 录 静 态 效 果 





1) 该 页 面 制作 比较 简单 ， 主 要 的 功能 代码 如 下 : 


< script language = " JavaScript" > 

function chkinput( form) | 

if( form. name. value == "")| 

alert ( " iffi AP 41"); 

form. name. select( ) ; 

return( false) ; 
| 
if( form. pwd. value 22 "" ) | 

alert(" 请 输入 用 户 密码 1" ) ; 

form. pwd. select( ) ; 

return( false) ; 
| 
return( true ) ; 

1// 单 击 登录 按钮 进行 表单 的 验证 
</script > 
<form name =" forml" method =" post" action =" chkadmin. php" onSubmit =" return. chkinput(this)" > 
// 通 过 验证 后 , 转 到 chkadmin. php 进行 判断 


2) chkadmin. php 是 判断 管理 员 身 份 是 否 正确 的 页 面 ， 使 用 PHP 编写 的 程序 如 下 : 


< ?php 
class chkinput | 
var$name; 
var$pwd; 
function chkinput( $x, $y) 
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$this -> name = $x; 
$this -> pwd = $y; 
| 
function checkinput( ) 
| 
include( " conn/ conn. php" ) ; 
$sql = mysql. query( " select * from tb. admin where name + ". $this —» name. " " ,$conn);// 从 数据 
K tb. admin 调 出 数据 
$info = mysql. fetch. array ($sql) ; 
if( $info == false) 
| 





echo " < script language + javascript > alert 不 存在 此 管理 员 !" ) ; history. back( ) ; 
</script>"; 
exit; 
1 如 果 不 存在 , 则 显示 为 "不 存在 此 管理 员 ” 
else 


| 








if($info[ pwd] ==$this -> pwd) | 
header( " location ; default. php" ) ; 
LZ WR TE , WSKR default. php 页 面 


else 





echo " < script language + javascript > alert (. 密码 输入 错误 ! ) ; history. back ( ) ; 
</script>"; 


exit; 


$obj = new chkinput( trim($_POST[ name] ) ,md5 ( trim($_POST[ pwd] ))); 
$obj -> checkinput( ) ; 


7» 


eo 树 状 菜单 的 设计 


后 台 管 理 的 导航 菜单 是 一 个 树 状 的 展开 式 菜单 ， 分 为 二 级 菜单 ， 在 单 击 一 级 菜单 
时 可 以 实现 二 级 菜单 的 展开 和 合并 的 操作 ， 在 Dreamweaver 中 设计 的 样式 如 图 10-9 
所 示 。 

而 实现 动态 的 展开 和 合并 是 使 用 JavaScript 实现 的 ， 核 心 的 代码 如 下 : 
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< script language =" JavaScript" > 
function openspgl( ) | 

if( document. all. spgl. style. display == " none" ) | 

document. all. spgl. style. display = 


"a". 
, 


document. all. dl. src = " images/point3. gif" ; 
| 
else f 

document. all. spgl. style. display = " none" ; 


document. all. dl. src = " images/pointl. gif" ; 


| 
| 


function openyhgl( ) | 
if( document. all. yhgl. style. display == " none" ) | 
document. all. yhgl. style. display = 


"n", 
, 


document. all. d2. src = " images/ point3. gif" ; 
| 
else | 

document. all. yhgl. style. display = " none" ; 


document. all. d2. src = " images/ pointl. gif" ; 


| 
| 
function openddgl( ) | 
if( document. all. ddgl style. display == " none" ) | 
document. all. ddgl. style. display = 


"n, 
, 


document. all. d3. src = " images/ point3. gif" ; 
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else | 
document. all. ddgl. style. display = " none" ; 
document. all. d3. src = " images/ pointl. gif" ; 
| 
| 
function opengggl( ) | 
if( document. all. gggl. style. display == " none" ) | 
document. all. ggel. style. display 2 "" ; 
document. all. d4. src = " images/point3. gif" ; 
| 
else| 
document. all. gggl. style. display = " none" ; 
document. all. d4. src = " images/pointl. gif" ; 
| 
| 


</script > 


上 述 的 代码 经 常 应 用 于 网 站 的 动态 菜单 设计 ， 读 者 可 以 将 其 应 用 于 其 他 的 网 站 ， 甚 至 是 
网 站 的 前 台 菜 单 。 





MO 商品 管理 功能 





根据 需求 ， 商 品 管理 功能 页 面包 括 了 增加 商品 (addgoods. php) 、 修 改 商 品 (editgoods. php) 、 
类 别管 理 (showleibie. php) 、 添 加 类 别 (addleibie. php) 4 个 功能 页 面 。 本 小 节 就 介绍 这 几 个 商 
品 管理 功能 页 面 程序 实现 方法 。 


UELLE 增加 商品 功能 


在 前 台 展 示 的 所 有 产品 都 是 从 后 台 进 行商 品 发 布 的 ， 供 商品 发 布 的 字段 要 与 数据 库 中 保 
存 商 品 的 设计 字段 一 一 对 应 。 实 例 所 设计 的 增加 商品 静态 页 面 addgoods. php 效果 如 图 10-10 
所 示 。 

1) addgoods. php 的 程序 核心 代码 如 下 。 





< script language = " JavaScript" > 
function chkinput( form) 
| 
if( form. mingcheng. value 22 "") 
| 
alert(" 请 输入 商品 名 称 !" ) ; 
form. mingcheng. select( ) ; 


return( false) ; 


| 
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从 入 门 到 精通 





gi CAxampphtdocsyshopyadminyaddgoods.php 





ITIN font. css conn. php 
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图 10-10 增加 商品 的 静态 页 面 效 果 


if( form. huiyuanjia. value == "") 
| 
alert(" 请 输入 商品 会 员 价 !" ) ; 
form. huiyuanjia. select( ) ; 
return( false) ; 
| 
if( form. shichangjia. value 22 "") 
| 
alert(" 请 输入 商品 市 场 价 !" ) ; 
form. shichangjia. select( ) ; 
return( false) ; 


| 


if( form. dengji. value =="" ) 


| 
alert(" 请 输入 商品 等 级 1" ) ; 
form. dengji. select( ) ; 
return( false) ; 
| 
if( form. pinpai. value == "") 
| 
alert(" 请 输入 商品 品牌 1" ) ; 
form. pinpai. select( ) ; 


return( false) ; 


| 
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if( form. xinghao. value =="" ) 
| 
alert(" 请 输入 商品 型 号 !" ) ; 
form. xinghao. select( ) ; 
return( false) ; 
| 
if( form. shuliang. value =="") 
| 
alert(" 请 输入 商品 数量 !" ) ; 


form. shuliang. select( ) ; 








return( false) ; 
| 
if( form. jianjie. value == "") 
| 
alert(" 请 输入 商品 简介 !" ) ; 
form. jianjie. select( ) ; 
return( false) ; 


| 


return( true ) ; 


« /script >// 进 行 表单 验证 


< form name =" forml" enctype =" 


multipart/form — data" method =" post" action = 
" savenewgoods. php" onSubmit = " return chkinput ( this)" > /验证 后 提交 savenewgoods. php 页 面 进 
行 处 理 


2) savenewgoods. php 是 实现 将 发 布 的 商品 信息 保存 到 数据 库 的 文件 ， 代 码 如 下 。 


< ?php 
include( " conn/conn. php" ) ; 
if( is numeric($. POST[ shichangjia] ) == false || is numeric($, POST[ huiyuanjia]) == false) 
| 
echo " < script > alert 价格 只 能 为 数字 !" ) ;history. back( ) ; </script>"; 
exit; 
| 
if(is_numeric($_POST[ shuliang] ) == false) 
| 
echo " < script > alert 数量 只 能 为 数字 !" ) ;history. back( ) ; </script>" ; 
exit; 
| 
$mingcheng 2$. POST[ mingcheng ] ; 
$nian 2$. POST| nian] ; 
$yue 2$. POST[ yue]; 
$r -$ POST[ri]; 
$shichangjia = $. POST[ shichangjia | ; 
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Shuiyuanjia =$_POST[ huiyuanjia ] ; 
$typeid 2$. POST[ typeid ] ; 
$dengji 2$. POST[ dengji | ; 
$xinghao 2$. POST[ xinghao] ; 
$pinpai 2$, POST[ pinpai ] ; 
$tuijian 2$. POST| tuijian] ; 
$shuliang 2 $. POST[ shuliang | ; 
Supfile 2$ POST[ upfile ] ; 
if( ceil( (Shuiyuanjia/$shichangjia) * 100) <= 80) 
| 
$tejia=1; 
| 
else 
| 
$tejia 20; 
| 


function getname($exname) | 
$dir = " upimages/" ;// 列 出 产品 图 片 的 上 传 目录 
$i=1; 
if( lis_dir($dir) ) | 
mkdir($dir,0777 ) ; 
| 


while( true) | 
if( lis, file(8dir. $i. ". ". $exname) ) | 
$name - $i. ". ". $exname; 
break; 

| 

$i++; 


| 


return $dir. $name; 
| 
$exname = strtolower( substr($_FILES{ upfilé ][ name ],(strrpos($, FILES[ upfilé ][ name ]',.' ) 
*1)); 
Suploadfile = getname($exname) ; 
move, uploaded, file($. FILES[ upfilé ][ tmp. name ] , $uploadfile) ; 
if(trim($ FILES[ upfilé ][ namé ]!2"")) 
| 
$uploadfile = " admin/". $uploadfile ; 
| 
else 


| 
$uploadfile =""; 
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$jianjie 2$. POST[ jianjie] ; 

$addtime = $nian. " — ". $yue. " — ". $ri; 

mysql. query( " insert into tb. shangpin ( mingcheng ,jianjie , addtime , dengji , xinghao , tupian , typeid , shich- 

angjia, huiyuanjia , pinpai , tuijian , shuliang , cishu ) values( $ mingcheng ', $jianjié ', $addtime ', $dengji , E 

' $xinghaó , $ uploadfilé ', $ typeid ', $ shichangjià ', $ huiyuanjiá ', $ pinpai ', $ tuijiau ', $ shuliang , 

' 0 )",$conn) ; 2 
echo " < script > alert 商品 ". $mingcheng." 添 加 成 功 ! ) ; window. location. href + addgoods. php ; 


</script>"; 
? >// 上 传 成 功 转向 addgoods. php 页 面 


述 PHP 的 程序 编写 中 ， 核 心 在 于 产品 图 片 的 上 传 功能 。 


CDD 修改 商品 功能 


在 商品 发 布 后 ， 如 果 发 现 发 布 的 商品 信息 有 错误 ， 可 以 通过 单 击 “修改 商品 ”功能 来 
进行 商品 信息 的 调整 。 在 后 台中 单 击 “ 修 改 商 品 ”， 打 开 的 是 editgoods. php 页 面 。 
1) 使 用 Dreamweaver 制作 的 静态 页 面 效 果 如 图 10-11 所 示 。 








$ C:\xampp\htdocs\shop\admin\editgoods.php -0x 
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图 10-11 修改 商品 静态 页 面 效 果 





2) 在 该 页 面 中 可 以 选择 “ 复 选 ” 复 选 框 ， 再 单 击 “ 删 除 选 项 ”按钮 实现 商品 删除 的 操 
作 ， 链 接 到 deletefxhw. php 进行 删除 操作 。deletefxhw. php 是 从 数据 库 中 删除 该 商品 信息 ， 使 
用 的 代码 如 下 。 


< ?php 





include( " conn/conn. php" ) ; 
while( list( $name , $value) = each($. POST) ) 
| 
$sql = mysql_query( " select tupian from tb_shangpin where id = ". $value. " " ,$conn); 
$info = mysql. fetch. array ($sql) ; 
if(Sinfo[ tupian] !="") 
| 
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Q unlink( substr($info[ tupian | ,6, ( strlen ($info[ tupian] ) -6))) ; 
| 
$sqll = mysql_query("select * from tb dingdan " ,$conn); 
while( $infol = mysql_fetch_array($sqll ) ) 
| $idl =$infol [id]; 
$array = explode( " 9 " ,$infol [ spe]) ; 
for($i 20;$i < count(Sarray) ;$i ++ ) | 
if(Sarray[$1] == $value) 


mysql_query ( " delete from tb_dingdan where id = ". $id1. " " ,$conn); 


mysql_query ( " delete from tb_shangpin where id = ". $value. " " ,$conn) ; 
mysql. query( " delete from tb. pingjia where spid = ". $value. " " ,$conn) ; 
| 
header( " location :editgoods. php" ) ; 
7» 


3) 通过 单 击 “ 更 改 ” 文 字 链 接 能 打开 changegoods. php 页 面 进行 商品 的 信息 变更 ， 该 
页 面 设计 的 样式 和 添加 产品 时 的 样式 是 一 样 的 ， 如 图 10-12 所 示 。 
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10-12 商品 的 信息 变更 页 面 





4) 在 编辑 商品 信息 之 后 ， 单 击 “更 改 ” 按 钮 提交 表单 到 savechangegoods. php 页 面 进行 
数据 库 的 更 新 操作 ， 核 心 代码 如 下 。 


< meta http — equiv = " Content — Type" content = " text/html; charset = gb2312" > 
< ?php 


include( " conn/conn. php" ) ; 
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$mingcheng =$_POST| mingcheng ] ; 
$nian 2$. POST| nian] ; 

$yue 2$. POST[ yue]; 

$r 2$ POST[ri]; 

Sshichangjia 2 $. POST[ shichangjia ] ; 
Shuiyuanjia 2$. POST[ huiyuanjia ] ; 
$typeid 2$. POST[ typeid ] ; 

$dengji 2$. POST[ dengji | ; 
$xinghao 2$. POST[ xinghao] ; 
$pinpai 2$, POST[ pinpai ] ; 

$tuijian 2$. POST| tuijian] ; 
$shuliang =$_POST[ shuliang] ; 
//$upfile 2$. POST[ upfile | ; 





if( ceil( (Shuiyuanjia/$shichangjia) * 100) <=80) 
| 
$tejia=1; 
| 
else 
| 
$tejia =0; 
| 
if($upfile!="") 
| 
$sql = mysql_query("select * from tb_shangpin where id =". $ GET[ id]. "" ,$conn); 
$info = mysql. fetch array ($sql) ; 
Q unlink ( substr($info[ tupian ] ,6 , (strlen( $info[ tupian]) -6) ) ) ; 
| 


function getname($exname) | 
$dir = " upimages/" ; 
$i=1; 
if( lis_dir($dir) ) | 
mkdir($dir,0777 ) ; 


while( true) | 
if( lis, file(8dir. $i. ". ". $exname) ) | 
$name - $i. ". ". $exname; 
break; 

| 

$i++; 


| 
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return $dir. $name; 


$exname = strtolower( substr($. FILES[ upfilé ][ namé ],(strrpos($, FILES[ upfilé ][ name ]', .' ) 
+1))); 

Suploadfile = getname($exname) ; 

move, uploaded, file($. FILES[ upfilé ][ tmp. name ] , Suploadfile) ; 

Suploadfile = " admin/". $uploadfile; 

$jianjie 2$. POST[ jianjie] ; 

$addtime = $nian. " — ". $yue. " — ". $ri; 

mysql_query ( " update tb, shangpin set mingcheng = $ mingcheng , jianjie 5 $ jianjié , addtime = 
' $addtimé , dengji = $dengji , xinghao = $xinghaó , tupian = $ uploadfilé ,typeid = $typeid , shich- 
angjia = $shichangjià ,huiyuanjia 5 $huiyuanjià ,pinpai = $pinpal ,tuijian = $tuijiań ,shuliang = $shu- 
liang where id =". $ GET|[ id]. "" , $conn) ; 

echo " < script > alert( 商品 ". $mingcheng. "修改 成 功 ! ) ; history. back( ) ; ; </script>" ; 
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更 新 数据 库 主要 应 用 到 了 update 这 个 数据 库 更 新 命令 。 


(ESL 删除 类 别 功能 


商品 的 类 别提 供 了 删除 功能 ， 通 过 选择 “操作 ” 复 选 框 再 单 击 “ 删 除 选 项 ” 即 可 以 将 
类 别 从 数据 库 中 删除 。 该 功能 首页 为 showleibie. php, 

1) 使 用 Dreamweaver 10-13 所 示 。 该 页 面 主要 实现 从 类 
别 的 数据 表 中 查询 出 相应 的 数据 绑 定 到 该 页 
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10-13 删除 类 别 页 面 


2) 选择 相应 的 类 别 复 选 框 ， 再 单 击 “ 删 除 选项 ”， 提 交 表 单 到 deletelb. php 动态 页 面 
行 删除 。 在 删除 时 ， 要 把 相关 联 的 商品 信息 也 一 并 删除 ， 即 通 过 商品 的 ID 同时 删除 tb. type 
和 也 _shangpin。 实 现 删 除 类 别 的 代码 如 下 。 





< ?php 
include( " conn/conn. php" ) ; 
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while( list($name, $value) = each($_POST) ) | 
mysql. query ( " delete from tb type where id + ". $value. " " , $conn) ;// 删 除 类 别 
mysql. query ( " delete from tb, shangpin where id 5 ". $value. " " ,$conn) ;// 删 除 类 别 下 的 商品 


| e 
header( " location ; showleibie. php" ) ;// 删 除 成 功 , 则 转向 showleibie. php 页 面 
7» 


(UP E. 添加 类 别 功 能 


电子 商务 网 站 的 商品 是 多 种 多 样 的 ， 在 后 台 要 设置 商品 分 类 的 功能 。 在 实际 的 网 站 开发 
中 经 常 有 一 级 分 类 、 二 级 分 类 ， 其 至 三 级 分 类 都 有 ， 这 些 还 涉及 菜单 的 二 级 联动 问题 。 本 实 
例 只 建立 了 一 级 分 类 ， 管 理 员 可 以 在 后 台 直 接 添加 一 级 的 分 类 ， 添 加 类 别 功 能 的 主页 面 是 
addleibie. php。 

1) 使 用 Dreamweaver 设计 addleibie. php 页 面 的 静态 效果 如 图 10-14 所 示 。 
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图 10-14 添加 类 别 页 面 的 静态 效果 


2) 在 单 击 “ 增 加 ”按钮 的 时 候 ， 要 先进 行 表 单 验证 ， 再 提交 到 saveaddleibie. php 页 面 ， 
进行 插入 数据 库 的 操作 。 该 页 面 的 代码 如 下 。 


$leibie 2$. POST[ leibie ] ; 
include( " conn/conn. php" ) ; 
$sql = mysql. query ("select * from tb. type where typename = ". $leibie. " " ,$conn) ; 
$info = mysql. fetch array ($sql) ; 
if( $info!- false) | 
echo" < script > alert( 该 类 别 已 经 存在 ! ) ;window. location. href + addleibie. php ; </script>"; 
exit ; 
1 /判断 类 别 是 否 存在 
mysql. query ( " insert into tb. type(typename) values ( $leibié )" ,$conn) ; 
echo" < script > alert( 新 类 别 添加 成 功 ! ) ; window. location. href + addleibie. php ; </script>" ; 
? >// 添 加 成 功 指向 addleibie. php 


在 编写 的 时 候 要 充分 考虑 到 类 别 是 否 已 经 存在 ， 因 此 需要 加 入 一 个 判断 环节 。 
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用 户 管理 功能 
用 户 管理 功能 与 前 台 的 用 户 注册 功能 互相 呼应 ， 对 于 一 个 购物 网 站 来 说 ， 一 个 完善 的 用 


户 管理 系统 一 定 要 有 一 个 功能 比较 强大 的 用 户 后 台 管 理 ， 实 例 中 制作 了 “会 员 管理 ”、“ 留 
言 管理 ”、“ 更 改 管理 员 ”3 个 菜单 项 ， 本 小 节 就 介绍 这 几 个 小 功能 的 实现 方法 。 





IU 会 员 管理 功能 


会 员 的 管理 功能 主要 是 指 能 够 在 后 台 实 现 会 员 的 删除 ， 对 一 些 会 
的 操作 ， 保 留 会 员 的 信息 但 禁止 其 在 前 台 进 行 购物 及 发 言 。 会 员 管理 
er. php, ， 制 作 的 详细 步骤 如 下 。 

1) 使 用 Dreamweaver 设计 的 会 员 管理 页 面 如 图 10-15 所 示 。 


员 能 够 实现 “冻结 ” 
功能 的 首页 为 editus- 
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10-15 会 员 管理 页 面 


2) 选择 “删除 ” 复 选 框 ， 再 单 击 “ 删 除 选项 ”时 ， 能 够 提交 表单 到 deleteuser. php 动 
态 页 面 ， 即 可 实现 会 员 数 据 删除 的 操作 。 该 页 面 的 程序 如 下 。 


< ?php 
include( " conn/conn. php" ) ; 
while(list( $name , $value) = each($. POST) ) 
| 
mysql. query( " delete from tb. user where id =". $value. "" ,$conn); 
mysql. query( " delete from tb. pingjia where userid = ". $value. "" ) ; 
mysql. query ( " delete from tb, leaveword where userid =". $value. "" , $conn) ; 
| 
header( " location :edituser. php" ) ; 


7» 


在 删除 会 员 的 时 候 ， 同 样 要 注意 删除 数据 库 中 tb user. tb pingjia, tb leaveword 这 3 个 
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数据 表 中 所 有 关联 的 数据 ， 删 除 成 功 后 要 返回 会 员 管 理 主页 面 。 
3) 在 单 击 “ 查 看 详细 ”链接 后 ， 将 打开 对 用 户 信息 “冻结 ”和 “解冻 ”的 页 面 looku 
serinfo. php ， 该 查看 用 户 信 息 的 页 面 如 图 10-16 所 示 。 





$ C:\xampp\htdocs\shop\admin\lookuserinfo.php = 
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图 10-16 ”查看 用 户 信息 页 面 


编写 实现 对 用 户 信 息 “ 冻 结 ” 和 “解冻 ”的 程序 其 实 非 常 简单 ， 只 要 赋值 为 0 或 者 1 
来 区 分 是 否 冻 结 ， 在 查询 会 员 信息 的 时 候 就 能 够 按 查 询 是 0 或 者 是 1 来 给 会 员 权 限 。 代 码 
如 下 : 














< ?php 
$sql =mysql_query( " select * from tb, user where id =". $id. "" ,$conn) ; 
$info = mysql. fetch array ($sql) ; 
if( $info[ dongjie ] == 
| 
echo "冻结 该 用 户 " ; 
| 


else 
| 
echo "解除 冻结 " ; 


当 会 员 在 购物 时 遇 到 问题 ， 可 以 直接 通过 留言 功能 和 管理 员 进行 沟通 ， 后 台 管理 员 要 及 
时 浏览 会 员 的 留言 并 进行 相应 的 处 理 ， 对 于 一 些 没 用 的 留言 可 以 直接 删除 。 用 于 留言 管理 的 
页 面 是 lookleaveword. php. 

1) 制作 的 留言 处 理 页 面 lookleaveword. php 效果 如 图 10-17 所 示 。 

2) 该 页 面 主要 是 从 数据 库 中 查询 所 有 的 留言 并 显示 在 网 页 中 ,在 选择 “删除 ” 复 选 
框 ， 再 单 击 “ 删 除 选 项 ”时 ， 提 交 表 单 信息 至 deleteleaveword. php 页 面 进行 删除 数据 的 操 
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10-17 留言 处 理 页 面 


作 。 实 现 删 除 的 代码 如 下 : 


< ?php 
include( " conn/conn. php" ) ; 
while(list( $name , $value) = each($. POST) ) 


| 


mysql. query( " delete from tb. leaveword where id = ". $value. " " ,$conn); 


| 


header( " location :lookleaveword. php" ) ; 


? >// 删 除 成 功 返 回 lookleaveword. php 


HIERRO 更 改 管理 员 功 能 


网 站 开发 者 在 开发 时 一 般 使 用 的 用 户 各 和 密码 都 是 admin， 在 提交 给 网 站 管理 员 时 ， 为 
了 安全 起 见 ， 管 理 员 要 能 够 实现 后 台 管 理 员 的 用 户 名 和 密码 的 修改 。 实 现 该 功能 的 页 面 是 
changeadmin. php, 

1) 制作 的 更 改 管理 员 页 面 changeadmin. php 的 效果 如 图 10-18 所 示 。 
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图 10-18 网 站 管理 员 后 台 修改 页 面 


2) 输入 新 旧 管 理 员 的 用 户 名 和 密码 ， 再 单 击 “ 更 改 ”按钮 ， 可 以 提交 表单 进行 验证 ， 
然后 提交 到 savechangeadmin. php 进行 数据 更 新 的 操作 。 实 现 的 代码 如 下 : 
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< ?php 

$n0 2$. POST[ n0] ; 

$nl =$_POST[nl ] ; 

$p0 =md5($_POST[ p0]) ; 

$pl =trim($_POST[p1]); 

include( " conn/conn. php" ) ; 





$sql = mysql_query ( " select * from tb admin where name = ". $n0. " " ,$conn) ; 


$info = mysql. fetch. array ($sql) ; 
if( $info == false) 

| 
echo " < script > alert( 不 存在 此 用 户 !' ) ;history. back( ) ; «/script >"; 
exit; 

| 

else 

| 

if($info[ pwd] ==$p0) 

| 


if($n1!="") 
| 
mysql. query ( " update tb. admin set name + ". $nl. " where id =". $info[ id]. " ",$conn); 
| 
if(Spl Iz "") 


| 
$pl = md5($p1) ; 
mysql. query ( " update tb. admin set pwd = ". $pl. " where id = ". $info[ id]. "" ,$conn) ; 
| 
| 


else 


| 
echo " < script > alert 原 密码 输入 错误 1" ) ;history. back( ) ; </script>"; 


exit; 


| 
echo " < script > alert( 更 改 成 功 ! ) ;history. back( ) ; </script>" ; 
7» 


该 程序 首先 对 管理 员 的 用 户 名 进行 验证 ,判断 正确 后 才 进行 数据 更 新 ， 并 显示 更 新 
成 功 。 





EP 订单 管理 功能 


订单 管理 功能 是 购物 网 站 的 重点 ， 对 于 网 站 管理 员 而 言 ， 一 定 要 及 时 登录 后 台 对 订单 进 
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行 管理 并 及 时 发 货 。 实 例 在 登录 后 台 时 把 订单 管理 的 功能 放 到 了 默认 打开 的 页 面 ， 主 要 包括 
了 “编辑 订单 ”和 “查询 订单 ”2 个 小 功能 。 下 面 就 分 别 做 介绍 。 


TDP 是 编辑 订单 功能 

所 谓 的 编辑 订单 是 指 管理 员 在 登录 后 台 后 ， 对 会 员 提 交 的 订单 进行 “已 收 款 ”“ 已 发 
fe" “已 收 货 ” 等 验证 ， 同 时 要 及 时 打印 出 网 上 订单 并 提交 给 公司 进行 发 货 处 理 。 编 辑 订 单 
的 主页 是 lookdd. php。 

1) 设计 的 lookdd. php 页 面 的 效果 如 图 10-19 所 示 。 该 页 面具 有 简单 的 订单 信息 功能 ， 
只 要 从 数据 库 中 查询 订单 进行 显示 即 可 。 

















TÈ cvwampp\htdocsvshop\adminlookdd php. UE 
BIN font. ess conn. php T 
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图 10-19 编辑 订单 页 面 


2) 设计 的 第 二 步 就 是 实现 单 击 “ 查 看 ”按钮 时 ， 能 调 出 订单 的 详细 内 容 showdd. php 
页 面 ， 并 能 进行 打印 。 制 作 的 效果 如 图 10-20 所 示 。 








[^| CAxampphtdocsyshopyadminshowdd.php = 0% 
QUE font.css conn. php Yr 





打印 预览 || 打 En Í 





关闭 窗口 基建 时 间 : WB 





























图 10-20 ”订单 详细 内 容 页 面 
showdd. php 页 面 中 调用 函数 实现 打印 的 功能 ， 具 体 的 代码 如 下 : 
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< html > 

< head > 

< meta http ~ equiv = " Content ~ Type" content = " text/html; charset = gb2312" > 
< title > 商品 订单 </title > 





< link rel = " stylesheet" type = " text/css" href = " css/font. css" > 
<style type = " text/css" > 
<!-- 
@ media print | 
div | display : none| 
| 
. style3 | color; #990000 } 
A 
«/style > 
«/ head > 
< ?php 
include( " conn/conn. php" ) ; 
$id-$ GET[id]; 
$sql = mysql. query(" select * from tb dingdan where id = ". $id. " " ,$conn) ; 
$info = mysql. fetch, array ($sql) ; 
$spc =$infol spc ] ; 
$slc = $info[ slc] ; 
Sarraysp = explode( " 9 " ,$spc) ; 
Sarraysl = explode( " € " ,$slc) ; 
7» 
< body topmargin 2 "0" leftmargin = "0" bottommargin = "0" > 
«p» &nbsp; «/p» 
«table width = "600" border 2 "O" align = "center" cellpadding = "0" cellspacing 2 "0" > 
<tr align = " center" bgcolor = " £FFCF60" > 
<td height = "20" colspan 2 "2" bgcolor = "40099 FF" > 商品 订单 < /td > 
«/tr» 
«tr» 
<td width = "448" height 2 "20" > 订单 号 : < ?php echoSinfo[ dingdanhao] ;? > « /id > 
<td width = "152" > « div align = " right" > 
< script > 
function prn( ) | 
document. all. WebBrowserl. ExecWB(7,1) ; 
| 
« /script > /实现 打印 预览 的 功能 












<object ID = WebBrowserl | WIDTH =0 HEIGHT =0 CLASSID + CLSID:8856F961 - 340A 


-]1D0 - A96B -00CO4FD705A2 > «/object > 


WA 


< input type = " button". value =" 打印 预 览 " class = " buttoncss" onClick = "prn( ) " > &nbsp; 


< input type = " button" value = " 打印 " class = " buttoncss" onClick =" window. print( )" > «/div > 


</td >// 实 现 打 印 的 功能 
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</tr> 
<tr> 
<td height ="20" colspan ="2" > 商品 列表 (如 下 ): < /td > 
</tr> 
</table > 


«table width = "500" height ="60" border ="0" align =" center" cellpadding = "0" cellspacing ="0" > 
«tr» 
< td bgcolor = " #666666" > < table width = "500" border = "O" align =" center" cellpadding = 
"0" cellspacing = "1" > 
< tr bgcolor = " #0099FF" > 
<td width = "153" height 2 "20" > 商品 名 称 < /td > 
<td width = "80" > 市场 价 </td > 
<td width = "80" > 会 员 价 </td > 
<td width = "80" > 数量 < /td > 
<td width 2 "101" » / vif «/td > 
</tr> 
< ?php 
$total 20; 
for($i =0;$i < count($arraysp) -1;$i ++ ) | 
if($arraysp[$i]!="")] 
$sqll = mysql. query ( " select * from tb_shangpin where id + ". $arraysp[$i]. " " ,$conn); 
$infol = mysql. fetch. array ($sqll) ; 
$total = $total += $arraysl[$i] *$infol[ huiyuanjia ] ; 
7» 
< tr bgcolor = " #FFFFFF" > 
« td height 2 "20" > < ?php echo $infol[ mingcheng] ;? > </td > 
<td height = "20" > < ?php echo $infol [ shichangjia] ;? > </td > 
<td height 2 "20" > < ?php echoS$infol [ huiyuanjia] ;? > </td > 
<td height = "20" > < ?php echo $arraysl[$i] ;? > </td > 
<td height = "20" > < ?php echo $arraysl[$i] *$info1 [ huiyuanjia] ;? > </td > 
</tr> 
< ?php 


| 


?> 
«tr bgcolor = " £FFFFFF" > 
<td height = "20" colspan 2 "5" > 
总 计 费 用 . < ?php echo$total;? > 
</td> 
</tr> 
</table > «/td > 
</tr> 
« /table > 
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«table width = "460" border 2 "0" align = "center" cellpadding = "0" cellspacing = "0" > 
«tr» 
<td width 2 "81" height = "20" > 下 单 人 : </td> 
<td colspan 2 "3" > < ?php echo$infol xiadanren] ;? > «/id > 
</tr> 
«tr» 
<td height = "20" > 收 货 人 : </td> 
< td height ="20" colspan ="3" > <?php echo $info[ shouhuoren] ;? > «/td > 





</tr> 
<tr> 
<td height 2 "20" > 收 货 人 地 址 : < /td > 
<td height 2 "20" colspan ="3" > <?php echo $info[ dizhi] ;? > </td > 
</tr> 
«tr» 
<td height = "20" > 邮 &nbsp; &nbsp; fi : « /td > 
<td width = "145" height = "20" > <?php echo $info[ youbian] ;? > </td > 
<td width = "66" > E &nbsp; &nbsp; ifi; </td > 
<td width 2 "158" > <?php echoSinfo[ tel] ;? > </td > 
</tr> 
<tr> 
<td height 2 "20" » E — mail; </td > 
<td height = "20" > < ?php echo $info[ email] ;? > </td > 
<td height 2 "20" > &nbsp; </td > 
<td height = "20" > &nbsp; </td > 
</tr> 
«tr» 
<td height 2 "20" > 送 货 方 式 : </td > 
<td height ="20" > <?php echo $info[ shff] ;? > </td > 
<td height 2 "20" > 支付 方式 : </td > 
<td height ="20" > <?php echo$info[ zfff] ;? > </td > 
</tr> 
«tr» 
<td height 2 "20" colspan 2 "4" > <span class =" inputessnull" > 汇款 时 注 明 您 的 订单 号 ! 汇 
款 后 请 及 时 联系 我 们 ! </span> </td> 
</tr> 
<tr> 
<td height 2 "20" > &nbsp; </td > 
<td height 2 "20" > < div align =" center" > « input type =" button" onClick = " window. close ( ) " 
value = "关闭 窗口 " class =" buttoncss" > </div > </td> 
«1d height 2 "20" > 创建 时 间 : < /td > 
<td height = "20" > < ?php echo $info[ time] ;? > </td > 
</tr> 





</table > 









© o o 
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</body > 
</html > 


3) 要 实现 订单 的 网 上 处 理 ， 单 击 “ 执 行 ”按钮 即 可 以 打开 orderdd. php 页 面 ， 进 行 订 
单 的 处 理 。 其 中 包括 了 “已 收 款 ”“ 已 发 货 *“ 已 收 货 ”3 个 复 选 框 ， 对 其 进行 相应 的 处 理 ， 


如 图 10-21 所 示 。 


fE] C\xampp\htdocs\shop\admin\orderdd.ph] 
(à E Pnp 
RD font.css conn. php 





= Dx 


















































E E EH eo x 4x. 

















10-21 执行 订单 页 面 


4) 单 击 “ 人 修改” 按钮 即 提交 表 到 saveorder. php 进行 修改 数据 的 保存 ， 具 体 的 代码 
如 下 。 


< ?php 

$ysk 2$. POST[ ysk ]. " &nbsp;" ; 
$yfh =$_POST[ yfh ]. " &nbsp;" ; 
$ysh =$_POST[ ysh]. " &nbsp;" ; 


$zt = "m ; 
if($ysk!= " &nbsp;" ) | 
$zt. =$ysk; 


| 
if($yfh!=" &nbsp;" ) | 
$zt. =$yfh; 
| 
if($ysh!l=" &nbsp;" ) | 
$zt. -$ysh; 
| 
if( ($ysk == " &nbsp;" ) &&($yfh ==" &nbsp;" )&&($ysh == " &nbsp;" ) ) | 
echo " < script > alert( 请 选择 处 理 状态 1 ) ; history. back( ) ; </script>" ; 


exit ; 
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include( " conn/conn. php" ) ; 

$sql3 = mysql. query(" select * from tb dingdan where id + ". $ GET[ id]. " " ,$conn) ; 
$info3 = mysql. fetch array ($sql3) ; 

if( trim(Sinfo3[ zt] ) == "未 作 任何 处 理 " ) | 

$sql = mysql_query("select * from tb_dingdan where id = ". $ GET[ id]. " " ,$conn) ; 





$info = mysql. fetch array ($sql) ; 
Sarray = explode( " 9 " ,$info[ spc] ) ; 
Sarraysl = explode( " @ " , $info[ slc] ) ; 


for($i 20;$i < count(S$array) ;$i ++ ) | 
$id = $array[$i ] ; 
$num = $arraysl [$i ] ; 
mysql_query ( " update tb_shangpin set cishu = cishu + ". $num. " ,shuliang = shuliang + ". $num. " 
where id + ". $id. " " , $conn) ; 
| 
| 


mysql. query ( " update tb_dingdan set zt 5 ". $zt. " where id + ". $ GET[ id]. " " ,$conn) ; 
header( " location ; lookdd. php" ) ; 
7» 


通过 上 述 4 个 步骤 的 设计 ， 后 台 的 订单 编辑 功能 即 开发 完成 。 


IP ES 查 询 订 单 功能 


在 网 站 运营 一 段 时 间 后 ， 网 上 的 订单 会 越 来 越 多 ， 也 经 常会 遇 到 会 员 查 询 订单 的 事情 ， 
网 站 管理 员 同 样 也 需要 一 个 订单 后 台 查 询 功能 ， 才 能 方便 地 找到 相应 的 订单 。 实 例 查询 和 显 
示 的 结果 是 在 同一 个 页 面 ， 即 finddd. php, 

1) 制作 的 finddd. php 页 面 效 果 如 图 10-22 所 示 。 








B C:\xampp\htdocs\shop\admin\finddd.php -TI 
HEUS font.css conn. php T 
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2) 核心 程序 如 下 。 





< html > 
< head > 
< meta http ~ equiv = " Content ~ Type" content = " text/html; charset = gb2312" > 
< title > 订单 查询 </title > 
< link rel = " stylesheet" type = " text/css" href = " css/font. css" > 
«/head > 
< ?php 
include( " conn/conn. php" ) ; 
7» 
< body topmargin 2 "0" leftmargin = "O0" bottommargin = "0" > 
«p» &nbsp; «/p» 
«table width = "550" border 2 "0" align = "center" cellpadding = "0" cellspacing 2 "0" > 
<tr> 
< td height 2" 20" bgcolor 2 " #0099FF" > < div align = " center" style = " color: 
#FFFFFF" > 订单 查询 </div> </td> 
</tr> 
<tr> 
<td height = "50" bgcolor = " #555555" > «table width = "550" height = "50" border = 
"0" align = "center" cellpadding = "0" cellspacing 2 "1" > 
«tr» 
<td bgcolor = " #FFFFFF" > 
<table width = "550" height = "50" border ="0" align =" center" cellpadding = "0" cellspacing = "0" > 
< script language = " javascript" > 


function chkinput3 ( form) 


if( (form. username. value == "" ) &&(form. ddh. value == "")) 
| 
alert(" 请 输入 下 订单 人 或 订单 号 " ) ; 
form. username. select( ) ; 
return( false) ; 


| 


return( true ) ; 


«/script > 
< form name = "form3" method = " post" action = " finddd. php" onSubmit = " return 
chkinput3( this)" > 
<tr> 
< td height 2 "25" > < div align 2 " center" > 下 订单 人 姓名 : < input type = 
"text" name = "username" class =" inputcss" size = "25" > 


订单 号 : «input type =" text" name ="ddh" size ="25" class = "inputess" > </div> </td> 
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</tr> 
<tr> 
<td height 2 "25" > 


< div align = " center" > e 
< input type = " hidden" value = " show, find" name =" show. find" > 





<input name = " button" type =" submit" class = " buttoness" id =" but- 
ton" value =" Æ 4X" > 
</div> </td> 
</tr> 
</form > 
</table > «/td > 
</tr> 
</table > «/td > 

</tr> 

</table > 
< table width = "550" height = "20" border = "0" align =" center" cellpadding = "0" cellspac- 

ing="0" > 

«tir» 

<td > &nbsp; </td > 
</tr> 
« /table > 
« ?php 
if($ POST[ show. find] !2 "")| 
$username = trim( $. POST| username | ) ; 
$ddh = trim($. POST[ ddh] ) ; 
if($username 22 "") | 
$sql = mysql query("select * from tb dingdan where dingdanhao = ". $ddh. " " , $conn) ; 


| 


elseif($ddh 22 "")| 
$sql = mysql query("select * from tb dingdan where xiadanren = ". $username. " " ,$conn) ; 
| 
else | 
$sql = mysql. query ("select * from tb, dingdan where xiadanren = ". $username. " and dingdan- 


hao = ". $ddh. " " ,$conn) ; 
| 
$info = mysql_fetch_array ($sql) ; 
if($info == false) | 
echo " < div algin 5 centet > 对 不 起 ,没有 查找 到 该 订单 ! </div>"; 
| 
else | 
?> 
< table width = "550" border = "0" align =" center" cellpadding = "0" cellspacing = "0" > 
<tr> 
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< td height =" 20" bgcolor =" #0099FF" > < div align =" center" style = " color; 
#FFFFFF" > 查询 结果 </div> </td> 
</tr> 
<tr> 
<td height = "50" bgcolor 2 " #555555" > «table width = "550" height = "50" border = 
"0" align = "center" cellpadding = "0" cellspacing 2 "1" > 
«tr» 
«td width = "77" height 2 "25" bgcolor = " &FFFFFF" > < div align = " center" > 订 
单 号 </div> </td> 
<td width = "77" bgcolor ="#FFFFFF" > <div align = " center" > 下 单 用 户 </div > 

















</td> 
<td width = "77" bgcolor = " #FFFFFF" > < div align = " center" > 订货 人 </div> 
</td> 
<td width = "77" bgcolor = "#FFFFFF" > « div align =" center" > 金额 总 计 </div > 
</td> 
<td width = "77" bgcolor = "#FFFFFF" > « div align 2 " center" > 付款 方式 </div > 
</td> 
<td width = "77" bgcolor = "#FFFFFF" > < div align =" center" > 收 款 方 式 </div > 
</td> 
<td width = "77" bgcolor = "#FFFFFF" > « div align 2 " center" > 订单 状态 </div > 
</td> 
</tr> 
< ?php 
do! 
?> 
«tr» 


<td height = "25" bgcolor = " £FFFFFF" > < div align = " center" > < ?php echo$info 
[ dingdanhao] ;? > «/div > «/td > 

<td height = "25" bgcolor = " £FFFFFF" > < div align = " center" > < ?php echo$info 
[ xiadanren] ;? > «/div > «/td > 

<td height = "25" bgcolor = " #FFFFFF" > < div align = " center" > < ?php echo$info 
[ shouhuoren ] ;? > «/div» </td > 

<td height 2 "25" bgcolor = " #FFFFFF" > < div align = " center" > < ?php echo$info 
[ total] ;? > </div > </td > 

<td height = "25" bgcolor = " £FFFFFF" > < div align = " center" > < ?php echo$info 
[ zfff] ;? > «/div > «/td > 

<td height = "25" bgcolor = " £FFFFFF" > < div align = " center" > < ?php echo$info 
[ shff] ;? > «/div > «/td > 

<td height 2 "25" bgcolor = " £FFFFFF" > < div align = " center" > < ?php echo$info 
[21];7 > </div> </td> 





</tr> 
< ?php 
| while ($info = mysql. fetch, array ($sql) ) ; 
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</table > </td > 
</tr> 
</table > 
< ?php 
| 
| 
7» 
«/ body > 
«/html > 


ES 信息 管理 功能 


信息 管理 功能 是 指 在 网 站 后 台 实 现 新 闻 、 用 户 的 商品 评价 等 相关 的 管理 操作 ， 本 实例 制 
作 了 管理 公告 、 发 布 公告 、 管 理 评价 3 个 功能 ， 通 过 这 3 个 功能 ， 能 够 实现 整个 网 站 的 即时 
公告 发 布 、 公 告 修改 ， 以 及 商品 评论 的 编辑 修改 功能 。 


10.5.1 


管理 公告 功能 是 指 可 以 在 后 台 对 发 布 的 公告 进行 修改 和 删除 。 管 理 公告 的 页 面 为 admin- 
gonggao. php. 
1) 制作 的 管理 公告 页 面 admingonggao. php 效果 如 图 10-23 所 示 。 





B CAxamppAhtdocsyshopyadminyadmingonggao.php EE 





edu» font. css conn. php 


管理 公告 


























图 10-23 管理 公告 页 面 





2) 选择 “选择 ” 复 选 框 ， 再 单 击 “ 删 除 所 选 ” 按 钮 ， 可 以 提交 表单 到 deletegong- 
gao. php， 进 行 删除 公告 的 操作 ， 代 码 如下。 
< ?php 
include( " conn/conn. php" ) ; 
while( list( $name , $value) = each($. POST) ) 
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mysql. query( " delete from th_gonggao where id = ". $value. " " ,$conn); 


| 


header( " location :admingonggao. php" ) ; 
7» 


面 如 图 10-24 所 示 。 





r 





C:xampp\htdocs\shop\admin\editgonggao.php = EX 
BURS font.css conn. php Y 
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4) 输入 修改 的 公告 主题 和 公告 内 容 ， 再 单 击 “ 更 改 ” 按 钮 ， 可 以 提交 表单 到 saveedit- 
gonggao，php， 进 行内 容 的 更 新 操作 ， 更 新 的 代码 如 下 : 


< ?php 

$title =$_POST[ title] ; 

$content 2 $. POST[ content] ; 

include( " conn/conn. php" ) ; 

mysql. query ( " update tb. gonggao set title + $titlé ,content + $content where id + ". $ POST[ id]. " ", 
$conn) ; 

echo " < script > alert 公告 修改 成 功 ! ) s history. back( ) ; </script>"; 


7» 


10.5.2 发 布 公告 功能 


用 于 添加 新 的 公告 的 页 面 是 addgonggao. php， 实 现 的 方法 就 是 采集 公告 的 字段 进行 数据 
的 插入 操作 。 本 小 节 就 介绍 添加 新 公告 的 具体 方法 。 

1) 添加 新 公告 页 面 addgonggao. php 如 图 10-25 所 示 。 

2) 录入 完 主题 和 内 容 ， 单 击 “ 添 加 ”按钮 ， 可 以 提交 表单 进行 验证 ， 并 提交 到 savene- 
wgonggao. php 页 面 ， 进 行 新 公告 的 保存 操作 。 实 现 的 代码 如 下 : 
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图 10-25 添加 新 公告 页 面 


< ?php 

include( " conn/conn. php" ) ; 

$title -$. POST[ title] ; 

$content 2$. POST[ content ] ; 

$time = date(" Y -m - j") ; 

mysql. query ( " insert into tb. gonggao (title, content, time) values ( $ titlė 


, $content ', $time )", 


$conn) ; 
echo " < script > alert 公告 添加 成 功 ! ) ; history. back( ) ; «/script > "; 
7» 

IUSSI 管理 评价 功能 


后 台 的 最 后 一 个 功能 是 管理 评价 功能 ， 通 过 管理 可 以 将 商品 的 一 些 负 面 信息 进行 删除 操 
作 。 管 理 评价 功能 的 页 面 是 editpinglun. php， 制 作 的 方法 如 下 。 
1) 编辑 用 户 评价 页 面 editpinglun. php 的 效果 如 图 10-26 所 示 。 








函 CAxampp\htdocs\shop\admin\editpinglun.php ax 
IS font. css conn. php Y 


编辑 用 户 评价 
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DS 


10-26 编辑 用 户 评 价 页 面 
2) 通过 单 击 “查看 ”文字 链接 ， 能 打开 Windows 窗口 显示 评价 的 详细 内 容 ， 实 现 的 代 














码 如 下 。 


< ?php 
include( " conn/conn. php" ) ; 
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$sql = mysql_query( " select count( * ) as total from tb. pingjia " ,$conn) ; 
$info = mysql. fetch array ($sql) ; 
$total = $info| total ] ; 
if( $total 220) 
| 
echo "本 站 和 暂 无 用 户 发 表 评 论 !" ; 
| 


else 


| 


?> 
< script language = " javascript" > 
function openpj ( id) 
| 
window. open( " lookpinglun. php?id =" +id," newframe" ," width = 500 , height = 300 , top = 100, left = 


200 , menubar = no , toolbar = no location = no , scrollbar = no „status = no" ) ; 


| 


«/script > 


3) 选择 “删除 ” 复 选 框 ， 再 单 击 “ 删 除 选项 ”按钮 ， 可 以 提交 表单 至 删除 评价 的 页 面 
deletepingjia. php, ， 该 页 面 的 代码 如 下 : 


< ?php 
include( " conn/conn. php" ) ; 
while(list( $name , $value) = each($. POST) ) 
| 
$id =$value; 
mysql_query( " delete from tb_pingjia where id =". $id. "" ,$conn) ; 
| 
header( " location :editpinglun. php" ) ; 
7» 


通过 上 述 几 大 后 台 管 理 功能 的 开发 ， 读 者 可 以 发 现 使 用 PHP 进行 网 上 后 台 管 理 系 统 的 


开发 其 实 并 不 难 。 正 所 谓 “ 磨 刀 不 误 砍 柴 工 " ， 在 开发 类 似 的 网 站 时 一 定 要 做 后 台 开 发 前 的 
架构 设计 ， 与 需求 方 沟通 到 位 ， 可 以 轻松 实现 网 站 的 开发 工作 。 





ISBN 978-7-111-51961-4 : 
: 官方 微 博 : http//weibo.com/cmpjsj 





策划 编辑 : T Wk ; oW i 
s : X PR 网 : http://site.douban.com/139085/ 
封面 设计 : Nilisecem ; 读者 信箱 : cmp_itbook@163.com 


: 互动 QQ 群 : 298191658 


ISBN 978-7-111-51961-4 
定价 : 69.00 元 







ISBN 978-7-111-51763-4 
定价 : 75.00 元 


é 


:| Dreamweaver ^^ 
动态 网 站 开发 从 入 门 到 藉 遂 


ISBN 978-7-111-37947-8 
定价 : 69.80 元 ( 含 1CD) 





m 


c w 


PAPASO Dreamen 








地 址 : 北京 市 百 万 庄 大 街 22 号 
邮政 编码 : 100037 

电话 服务 

服务 咨询 热线 : 010-88361066 


ISBN 978-7-111-51961-4 








读者 购书 热线 : 010-68326294 
010-88379203 
网 络 服务 
机 工 官网 : www.cmpbook.com 
机 工 官 博 : weibo.com/cmp1952| BSEESEENMEZP3 n 
ebook com | ISBN 978-7-111-51961-4 11 


封面 无 防伪 标 均 为 盗版 | 责任 编辑 丁 诚 / 封面 设计 人 〇 于 训 SS 定价 ; 69.00 元 


